Skip to content
项目
群组
代码片段
帮助
正在加载...
登录
切换导航
X
XXL-JOB
项目
项目
详情
活动
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
分枝图
比较
统计图
议题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
分枝图
统计图
创建新议题
作业
提交
议题看板
打开侧边栏
靳帅
XXL-JOB
Commits
15af500d
Unverified
提交
15af500d
authored
8月 16, 2018
作者:
许雪里
提交者:
GitHub
8月 16, 2018
浏览文件
操作
浏览文件
下载
差异文件
Merge pull request #403 from jackyRao2/master
修正xxl-job.xml端口自动获取的描述和执行器在指定ip自动获取端口时的错误
上级
8c2f50e9
76b629ac
隐藏空白字符变更
内嵌
并排
正在显示
3 个修改的文件
包含
29 行增加
和
10 行删除
+29
-10
XxlJobExecutor.java
...c/main/java/com/xxl/job/core/executor/XxlJobExecutor.java
+1
-1
NetUtil.java
...job-core/src/main/java/com/xxl/job/core/util/NetUtil.java
+27
-8
applicationcontext-xxl-job.xml
...-spring/src/main/resources/applicationcontext-xxl-job.xml
+1
-1
没有找到文件。
xxl-job-core/src/main/java/com/xxl/job/core/executor/XxlJobExecutor.java
浏览文件 @
15af500d
...
@@ -129,7 +129,7 @@ public class XxlJobExecutor implements ApplicationContextAware {
...
@@ -129,7 +129,7 @@ public class XxlJobExecutor implements ApplicationContextAware {
private
NetComServerFactory
serverFactory
=
new
NetComServerFactory
();
private
NetComServerFactory
serverFactory
=
new
NetComServerFactory
();
private
void
initExecutorServer
(
int
port
,
String
ip
,
String
appName
,
String
accessToken
)
throws
Exception
{
private
void
initExecutorServer
(
int
port
,
String
ip
,
String
appName
,
String
accessToken
)
throws
Exception
{
// valid param
// valid param
port
=
port
>
0
?
port:
NetUtil
.
findAvailablePort
(
9999
);
port
=
port
>
0
?
port:
NetUtil
.
findAvailablePort
(
9999
,
ip
);
// start server
// start server
NetComServerFactory
.
putService
(
ExecutorBiz
.
class
,
new
ExecutorBizImpl
());
// rpc-service, base on jetty
NetComServerFactory
.
putService
(
ExecutorBiz
.
class
,
new
ExecutorBizImpl
());
// rpc-service, base on jetty
...
...
xxl-job-core/src/main/java/com/xxl/job/core/util/NetUtil.java
浏览文件 @
15af500d
...
@@ -2,8 +2,10 @@ package com.xxl.job.core.util;
...
@@ -2,8 +2,10 @@ package com.xxl.job.core.util;
import
org.slf4j.Logger
;
import
org.slf4j.Logger
;
import
org.slf4j.LoggerFactory
;
import
org.slf4j.LoggerFactory
;
import
org.springframework.util.StringUtils
;
import
java.io.IOException
;
import
java.io.IOException
;
import
java.net.InetSocketAddress
;
import
java.net.ServerSocket
;
import
java.net.ServerSocket
;
/**
/**
...
@@ -15,23 +17,24 @@ public class NetUtil {
...
@@ -15,23 +17,24 @@ public class NetUtil {
private
static
Logger
logger
=
LoggerFactory
.
getLogger
(
NetUtil
.
class
);
private
static
Logger
logger
=
LoggerFactory
.
getLogger
(
NetUtil
.
class
);
/**
/**
* find avaliable port
* find avaliable port
by ip
*
*
* @param defaultPort
* @param defaultPort
* @param ip
* @return
* @return
*/
*/
public
static
int
findAvailablePort
(
int
defaultPort
)
{
public
static
int
findAvailablePort
(
int
defaultPort
,
String
ip
)
{
int
portTmp
=
defaultPort
;
int
portTmp
=
defaultPort
;
while
(
portTmp
<
65535
)
{
while
(
portTmp
<
65535
)
{
if
(!
isPortUsed
(
portTmp
))
{
if
(!
isPortUsed
(
portTmp
,
ip
))
{
return
portTmp
;
return
portTmp
;
}
else
{
}
else
{
portTmp
++;
portTmp
++;
}
}
}
}
portTmp
=
defaultPort
--
;
portTmp
=
--
defaultPort
;
while
(
portTmp
>
0
)
{
while
(
portTmp
>
0
)
{
if
(!
isPortUsed
(
portTmp
))
{
if
(!
isPortUsed
(
portTmp
,
ip
))
{
return
portTmp
;
return
portTmp
;
}
else
{
}
else
{
portTmp
--;
portTmp
--;
...
@@ -40,18 +43,34 @@ public class NetUtil {
...
@@ -40,18 +43,34 @@ public class NetUtil {
throw
new
IllegalStateException
(
"no available port."
);
throw
new
IllegalStateException
(
"no available port."
);
}
}
/**
* find avaliable port
*
* @param defaultPort
* @return
*/
public
static
int
findAvailablePort
(
int
defaultPort
)
{
return
findAvailablePort
(
defaultPort
,
null
);
}
/**
/**
* check port used
* check port used
*
*
* @param port
* @param port
* @param ip 为空则为 InetAddress.anyLocalAddress()
* @return
* @return
*/
*/
public
static
boolean
isPortUsed
(
int
port
)
{
public
static
boolean
isPortUsed
(
int
port
,
String
ip
)
{
boolean
used
=
false
;
boolean
used
=
false
;
ServerSocket
serverSocket
=
null
;
ServerSocket
serverSocket
=
null
;
try
{
try
{
serverSocket
=
new
ServerSocket
(
port
);
if
(
StringUtils
.
isEmpty
(
ip
)){
used
=
false
;
serverSocket
=
new
ServerSocket
(
port
);
}
else
{
serverSocket
=
new
ServerSocket
();
serverSocket
.
bind
(
new
InetSocketAddress
(
ip
,
port
));
}
}
catch
(
IOException
e
)
{
}
catch
(
IOException
e
)
{
logger
.
debug
(
">>>>>>>>>>> xxl-job, port[{}] is in use."
,
port
);
logger
.
debug
(
">>>>>>>>>>> xxl-job, port[{}] is in use."
,
port
);
used
=
true
;
used
=
true
;
...
...
xxl-job-executor-samples/xxl-job-executor-sample-spring/src/main/resources/applicationcontext-xxl-job.xml
浏览文件 @
15af500d
...
@@ -29,7 +29,7 @@
...
@@ -29,7 +29,7 @@
<property
name=
"appName"
value=
"${xxl.job.executor.appname}"
/>
<property
name=
"appName"
value=
"${xxl.job.executor.appname}"
/>
<!-- 执行器IP[选填],为空则自动获取 -->
<!-- 执行器IP[选填],为空则自动获取 -->
<property
name=
"ip"
value=
"${xxl.job.executor.ip}"
/>
<property
name=
"ip"
value=
"${xxl.job.executor.ip}"
/>
<!-- 执行器端口号[选填],为
空
则自动获取 -->
<!-- 执行器端口号[选填],为
<0
则自动获取 -->
<property
name=
"port"
value=
"${xxl.job.executor.port}"
/>
<property
name=
"port"
value=
"${xxl.job.executor.port}"
/>
<!-- 访问令牌[选填],非空则进行匹配校验 -->
<!-- 访问令牌[选填],非空则进行匹配校验 -->
<property
name=
"accessToken"
value=
"${xxl.job.accessToken}"
/>
<property
name=
"accessToken"
value=
"${xxl.job.accessToken}"
/>
...
...
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论