Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
PaddlePaddle
PaddleRec
提交
fcbb1cc0
P
PaddleRec
项目概览
PaddlePaddle
/
PaddleRec
通知
68
Star
12
Fork
5
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
27
列表
看板
标记
里程碑
合并请求
10
Wiki
1
Wiki
分析
仓库
DevOps
项目成员
Pages
P
PaddleRec
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
27
Issue
27
列表
看板
标记
里程碑
合并请求
10
合并请求
10
Pages
分析
分析
仓库分析
DevOps
Wiki
1
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
fcbb1cc0
编写于
5月 13, 2020
作者:
C
chengmo
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
for merge
上级
cd7cb08a
变更
3
显示空白变更内容
内联
并排
Showing
3 changed file
with
57 addition
and
10 deletion
+57
-10
fleet_rec/core/engine/local_cluster_engine.py
fleet_rec/core/engine/local_cluster_engine.py
+18
-6
fleet_rec/core/utils/envs.py
fleet_rec/core/utils/envs.py
+17
-4
readme.md
readme.md
+22
-0
未找到文件。
fleet_rec/core/engine/local_cluster_engine.py
浏览文件 @
fcbb1cc0
...
...
@@ -20,13 +20,14 @@ import os
import
copy
from
fleetrec.core.engine.engine
import
Engine
from
fleetrec.core.utils
import
envs
class
LocalClusterEngine
(
Engine
):
def
start_procs
(
self
):
worker_num
=
self
.
envs
[
"worker_num"
]
server_num
=
self
.
envs
[
"server_num"
]
start_port
=
self
.
envs
[
"start_port"
]
ports
=
[
self
.
envs
[
"start_port"
]
]
logs_dir
=
self
.
envs
[
"log_dir"
]
default_env
=
os
.
environ
.
copy
()
...
...
@@ -36,10 +37,19 @@ class LocalClusterEngine(Engine):
current_env
.
pop
(
"https_proxy"
,
None
)
procs
=
[]
log_fns
=
[]
ports
=
range
(
start_port
,
start_port
+
server_num
,
1
)
for
i
in
range
(
server_num
-
1
):
while
True
:
new_port
=
envs
.
find_free_port
()
if
new_port
not
in
ports
:
ports
.
append
(
new_port
)
break
user_endpoints
=
","
.
join
([
"127.0.0.1:"
+
str
(
x
)
for
x
in
ports
])
user_endpoints_ips
=
[
x
.
split
(
":"
)[
0
]
for
x
in
user_endpoints
.
split
(
","
)]
user_endpoints_port
=
[
x
.
split
(
":"
)[
1
]
for
x
in
user_endpoints
.
split
(
","
)]
user_endpoints_ips
=
[
x
.
split
(
":"
)[
0
]
for
x
in
user_endpoints
.
split
(
","
)]
user_endpoints_port
=
[
x
.
split
(
":"
)[
1
]
for
x
in
user_endpoints
.
split
(
","
)]
factory
=
"fleetrec.core.factory"
cmd
=
[
sys
.
executable
,
"-u"
,
"-m"
,
factory
,
self
.
trainer
]
...
...
@@ -56,7 +66,8 @@ class LocalClusterEngine(Engine):
os
.
system
(
"mkdir -p {}"
.
format
(
logs_dir
))
fn
=
open
(
"%s/server.%d"
%
(
logs_dir
,
i
),
"w"
)
log_fns
.
append
(
fn
)
proc
=
subprocess
.
Popen
(
cmd
,
env
=
current_env
,
stdout
=
fn
,
stderr
=
fn
,
cwd
=
os
.
getcwd
())
proc
=
subprocess
.
Popen
(
cmd
,
env
=
current_env
,
stdout
=
fn
,
stderr
=
fn
,
cwd
=
os
.
getcwd
())
procs
.
append
(
proc
)
for
i
in
range
(
worker_num
):
...
...
@@ -70,7 +81,8 @@ class LocalClusterEngine(Engine):
os
.
system
(
"mkdir -p {}"
.
format
(
logs_dir
))
fn
=
open
(
"%s/worker.%d"
%
(
logs_dir
,
i
),
"w"
)
log_fns
.
append
(
fn
)
proc
=
subprocess
.
Popen
(
cmd
,
env
=
current_env
,
stdout
=
fn
,
stderr
=
fn
,
cwd
=
os
.
getcwd
())
proc
=
subprocess
.
Popen
(
cmd
,
env
=
current_env
,
stdout
=
fn
,
stderr
=
fn
,
cwd
=
os
.
getcwd
())
procs
.
append
(
proc
)
# only wait worker to finish here
...
...
fleet_rec/core/utils/envs.py
浏览文件 @
fcbb1cc0
...
...
@@ -15,7 +15,7 @@
import
os
import
copy
import
sys
import
socket
global_envs
=
{}
...
...
@@ -78,7 +78,8 @@ def get_global_env(env_name, default_value=None, namespace=None):
"""
get os environment value
"""
_env_name
=
env_name
if
namespace
is
None
else
"."
.
join
([
namespace
,
env_name
])
_env_name
=
env_name
if
namespace
is
None
else
"."
.
join
(
[
namespace
,
env_name
])
return
global_envs
.
get
(
_env_name
,
default_value
)
...
...
@@ -146,7 +147,8 @@ def pretty_print_envs(envs, header=None):
def
lazy_instance_by_package
(
package
,
class_name
):
models
=
get_global_env
(
"train.model.models"
)
model_package
=
__import__
(
package
,
globals
(),
locals
(),
package
.
split
(
"."
))
model_package
=
__import__
(
package
,
globals
(),
locals
(),
package
.
split
(
"."
))
instance
=
getattr
(
model_package
,
class_name
)
return
instance
...
...
@@ -156,7 +158,8 @@ def lazy_instance_by_fliename(abs, class_name):
sys
.
path
.
append
(
dirname
)
package
=
os
.
path
.
splitext
(
os
.
path
.
basename
(
abs
))[
0
]
model_package
=
__import__
(
package
,
globals
(),
locals
(),
package
.
split
(
"."
))
model_package
=
__import__
(
package
,
globals
(),
locals
(),
package
.
split
(
"."
))
instance
=
getattr
(
model_package
,
class_name
)
return
instance
...
...
@@ -170,3 +173,13 @@ def get_platform():
return
"DARWIN"
if
'Windows'
in
plats
:
return
"WINDOWS"
def
find_free_port
():
def
__free_port
():
with
closing
(
socket
.
socket
(
socket
.
AF_INET
,
socket
.
SOCK_STREAM
))
as
s
:
s
.
bind
((
''
,
0
))
return
s
.
getsockname
()[
1
]
new_port
=
__free_port
()
return
new_port
readme.md
浏览文件 @
fcbb1cc0
...
...
@@ -97,6 +97,28 @@ python -m fleetrec.run -m fleetrec.models.rank.dnn -d cpu -e local_cluster
python
-m
fleetrec.run
-m
fleetrec.models.rank.dnn
-d
cpu
-e
cluster
```
<h2
align=
"center"
>
支持模型列表
</h2>
| 方向 | 模型 | 单机CPU训练 | 单机GPU训练 | 分布式CPU训练 | 大规模稀疏 | 分布式GPU训练 | 自定义数据集 |
| :------: | :--------------------: | :---------: | :---------: | :-----------: | :--------: | :-----------: | :----------: |
| 内容理解 |
[
Text-Classifcation
](
)
| ✓ | x | ✓ | x | ✓ | ✓ |
| 内容理解 |
[
TagSpace
](
)
| ✓ | x | ✓ | x | ✓ | ✓ |
| 召回 |
[
Word2Vec
](
)
| ✓ | x | ✓ | x | ✓ | ✓ |
| 召回 |
[
TDM
](
)
| ✓ | x | ✓ | x | ✓ | ✓ |
| 召回 |
[
SSR
](
)
| ✓ | ✓ | ✓ | x | ✓ | ✓ |
| 召回 |
[
Gru4Rec
](
)
| ✓ | ✓ | ✓ | x | ✓ | ✓ |
| 排序 |
[
CTR-Dnn
](
)
| ✓ | x | ✓ | x | ✓ | ✓ |
| 排序 |
[
DeepFm
](
)
| ✓ | x | ✓ | x | ✓ | ✓ |
| 排序 |
[
ListWise
](
)
| ✓ | x | ✓ | x | ✓ | ✓ |
| 排序 |
[
DSSM
](
)
| ✓ | x | ✓ | x | ✓ | ✓ |
| 排序 |
[
Multiview-Simnet
](
)
| ✓ | x | ✓ | x | ✓ | ✓ |
| 融合 |
[
MMOE
](
)
| ✓ | ✓ | ✓ | x | ✓ | ✓ |
| 融合 |
[
ESMM
](
)
| ✓ | ✓ | ✓ | x | ✓ | ✓ |
| 融合 |
[
ESMM
](
)
| ✓ | ✓ | ✓ | x | ✓ | ✓ |
<h2
align=
"center"
>
文档
</h2>
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录