Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
kanyxmo
MineAdmin
提交
0f8ee418
M
MineAdmin
项目概览
kanyxmo
/
MineAdmin
10 个月 前同步成功
通知
2
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
M
MineAdmin
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
前往新版Gitcode,体验更适合开发者的 AI 搜索 >>
未验证
提交
0f8ee418
编写于
5月 17, 2023
作者:
X
X.Mo
提交者:
GitHub
5月 17, 2023
浏览文件
操作
浏览文件
下载
差异文件
Merge pull request #55 from netyum/master
fix aarch64 systeminfo
上级
18caa23b
84ed7935
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
32 addition
and
4 deletion
+32
-4
app/System/Service/ServerMonitorService.php
app/System/Service/ServerMonitorService.php
+32
-4
未找到文件。
app/System/Service/ServerMonitorService.php
浏览文件 @
0f8ee418
...
...
@@ -15,7 +15,17 @@ class ServerMonitorService
try
{
if
(
PHP_OS
==
'Linux'
)
{
$cpu
=
$this
->
getCpuUsage
();
preg_match
(
'/(\d+)/'
,
shell_exec
(
'cat /proc/cpuinfo | grep "cache size"'
),
$cache
);
preg_match
(
'/(\d+)/'
,
shell_exec
(
'cat /proc/cpuinfo | grep "cache size"'
)
??
''
,
$cache
);
if
(
count
(
$cache
)
==
0
)
{
// aarch64 有可能是arm架构
$cache
=
trim
(
shell_exec
(
"lscpu | grep L3 | awk '{print
\$
NF}'"
));
if
(
$cache
==
''
)
{
$cache
=
trim
(
shell_exec
(
"lscpu | grep L2 | awk '{print
\$
NF}'"
));
}
if
(
$cache
!=
''
)
{
$cache
=
[
0
,
intval
(
str_replace
([
'K'
,
'B'
],
''
,
strtoupper
(
$cache
)))];
}
}
}
else
{
$cpuUsage
=
shell_exec
(
'top -l 1 | head -n 10 | grep CPU'
);
preg_match
(
'/(\d+\.\d+)%\suser/'
,
$cpuUsage
,
$cpu
);
...
...
@@ -45,7 +55,24 @@ class ServerMonitorService
public
function
getCpuName
():
string
{
if
(
PHP_OS
==
'Linux'
)
{
preg_match
(
'/^\s+\d\s+(.+)/'
,
shell_exec
(
'cat /proc/cpuinfo | grep name | cut -f2 -d: | uniq -c'
),
$matches
);
preg_match
(
'/^\s+\d\s+(.+)/'
,
shell_exec
(
'cat /proc/cpuinfo | grep name | cut -f2 -d: | uniq -c'
)
??
''
,
$matches
);
if
(
count
(
$matches
)
==
0
)
{
// aarch64 有可能是arm架构
$name
=
trim
(
shell_exec
(
"lscpu| grep Architecture | awk '{print $2}'"
)
??
''
);
if
(
$name
!=
''
)
{
$mfMhz
=
trim
(
shell_exec
(
"lscpu| grep 'MHz' | awk '{print
\$
NF}' | head -n1"
)
??
''
);
$mfGhz
=
trim
(
shell_exec
(
"lscpu| grep 'GHz' | awk '{print
\$
NF}' | head -n1"
)
??
''
);
if
(
$mfMhz
==
''
&&
$mfGhz
==
''
)
{
return
$name
;
}
else
if
(
$mfGhz
!=
''
)
{
return
$name
.
' @ '
.
$mfGhz
.
'GHz'
;
}
else
if
(
$mfMhz
!=
''
)
{
return
$name
.
' @ '
.
round
(
intval
(
$mfMhz
)
/
1000
,
2
)
.
'GHz'
;
}
}
else
{
return
'未知'
;
}
}
return
$matches
[
1
]
??
"未知"
;
}
else
{
return
shell_exec
(
'sysctl -n machdep.cpu.brand_string'
);
...
...
@@ -58,7 +85,8 @@ class ServerMonitorService
public
function
getCpuPhysicsCores
():
string
{
if
(
PHP_OS
==
'Linux'
)
{
return
str_replace
(
"
\n
"
,
''
,
shell_exec
(
'cat /proc/cpuinfo |grep "physical id"|sort |uniq|wc -l'
));
$num
=
str_replace
(
"
\n
"
,
''
,
shell_exec
(
'cat /proc/cpuinfo |grep "physical id"|sort |uniq|wc -l'
));
return
intval
(
$num
)
==
0
?
'1'
:
$num
;
}
else
{
return
trim
(
shell_exec
(
'sysctl -n hw.physicalcpu'
));
}
...
...
@@ -102,7 +130,7 @@ class ServerMonitorService
protected
function
calculationCpu
():
array
{
$mode
=
'/(cpu)[\s]+([0-9]+)[\s]+([0-9]+)[\s]+([0-9]+)[\s]+([0-9]+)[\s]+([0-9]+)[\s]+([0-9]+)[\s]+([0-9]+)[\s]+([0-9]+)/'
;
$string
=
shell_exec
(
'
more
/proc/stat | grep cpu'
);
$string
=
shell_exec
(
'
cat
/proc/stat | grep cpu'
);
preg_match_all
(
$mode
,
$string
,
$matches
);
$total
=
$matches
[
2
][
0
]
+
$matches
[
3
][
0
]
+
$matches
[
4
][
0
]
+
$matches
[
5
][
0
]
+
$matches
[
6
][
0
]
+
$matches
[
7
][
0
]
+
$matches
[
8
][
0
]
+
$matches
[
9
][
0
];
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录