跳到主要内容

银河麒麟(Kylin) OS

在本指南中,您将在Kylin V11 服务器上部署MyEMS。

前提

本指南介绍如何在KylinV11上安装MyEMS。硬件需求取决于所选数据库和连接到系统的设备数量。要在一台机器上运行MyEMS和MySQL,您至少需要8GB的RAM。

更新系统并安装工具:

sudo yum update
sudo yum install git
systemctl stop firewalld

克隆源代码:

cd ~
git clone https://gitee.com/myems/myems

第1步 数据库

参考 Database

第2步 myems-api

  • 安装 myems-api 服务:
sudo cp -r ~/myems/myems-api /myems-api
cd /myems-api
sudo pip install -r requirements.txt

根据example.env创建.env文件,并根据需要编辑.env:

sudo cp /myems-api/example.env /myems-api/.env
sudo nano /myems-api/.env

将端口添加到防火墙:

sudo firewall-cmd --zone=public --add-port=8000/tcp --permanent
sudo firewall-cmd --reload

安装 systemd 配置文件:

sudo cp /myems-api/myems-api.service /lib/systemd/system/
sudo cp /myems-api/myems-api.socket /lib/systemd/system/
sudo cp /myems-api/myems-api.conf /usr/lib/tmpfiles.d/

接下来启用这些服务,以便它们在启动时自动启动:

sudo systemctl enable myems-api.socket
sudo systemctl enable myems-api.service

启动服务:

sudo systemctl start myems-api.socket
sudo systemctl start myems-api.service

第3步 myems-admin

  • 安装 NGINX 服务器

参考 http://nginx.org/en/linux_packages.html#RHEL

启用nginx服务:

yum install -y nginx
sudo systemctl start nginx.service
  • 配置 NGINX
sudo vi /etc/nginx/nginx.conf

In the 'http' section, add some directives:

http {
client_header_timeout 600;
client_max_body_size 512M;
gzip on;
gzip_min_length 512;
gzip_proxied any;
gzip_types *;
gzip_vary on;
proxy_buffering off;
...

}

在目录 /etc/nginx/conf.d/ 下新建一个文件:

sudo vi /etc/nginx/conf.d/myems-admin.conf

编写如下指令, 如果myems-api服务运行在其它服务器上则用实际的地址替换 myems-api 默认地址 http://127.0.0.1:8000/

server {
listen 8001;
server_name myems-admin;
location / {
root /var/www/myems-admin;
index index.html index.htm;
}
## To avoid CORS issue, use Nginx to proxy myems-api to path /api
## Add another location /api in 'server'
## Replace the default myems-api url http://127.0.0.1:8000/ with actual url if the myems-api servcie hosted on different server
location /api {
proxy_pass http://127.0.0.1:8000/;
proxy_connect_timeout 75;
proxy_read_timeout 600;
send_timeout 600;
}
}
  • 安装 myems-admin : 如果服务器无法连接到internet,请压缩myems/myems-admin文件夹并将其上传到服务器,然后将其解压缩到~/myems/myems-admin
sudo mkdir /var/www
sudo cp -r ~/myems/myems-admin  /var/www/myems-admin
sudo chmod 0755 -R /var/www/myems-admin

检查配置文件,必要时进行更改:

sudo nano /var/www/myems-admin/app/api.js

警告

“upload”文件夹用于用户上传的文件。升级myems-admin时,请勿删除/移动/覆盖“upload”文件夹。

 /var/www/myems-admin/upload

将端口添加到防火墙:

sudo semanage port -a -t http_port_t  -p tcp 8001
sudo firewall-cmd --zone=public --add-port=8001/tcp --permanent
sudo firewall-cmd --reload

重启nginx服务:

sudo systemctl restart nginx.service

提示

如果您遇到“403 Forbidden”nginx错误,可以通过使用命令“sudo setforce 0”更改SELinx模式来修复它

第4步 myems-modbus-tcp

在此步骤中,您将安装myems-modbus-tcp服务。

sudo cp -r ~/myems/myems-modbus-tcp /myems-modbus-tcp
cd /myems-modbus-tcp
sudo pip install -r requirements.txt

将exmaple.ev文件复制到.env并修改.env文件:

sudo cp /myems-modbus-tcp/example.env /myems-modbus-tcp/.env
sudo nano /myems-modbus-tcp/.env

安装 systemd 服务:

sudo cp myems-modbus-tcp.service /lib/systemd/system/

启用服务:

sudo systemctl enable myems-modbus-tcp.service

启动服务:

sudo systemctl start myems-modbus-tcp.service

监控服务:

sudo systemctl status myems-modbus-tcp.service

查看日志:

cat /myems-modbus-tcp.log

第5步 myems-cleaning

在此步骤中,您将安装myems-cleaning服务。

sudo cp -r ~/myems/myems-cleaning /myems-cleaning
cd /myems-cleaning
sudo pip install -r requirements.txt

将exmaple.ev文件复制到.env并修改.env文件:

sudo cp /myems-cleaning/example.env /myems-cleaning/.env
sudo nano /myems-cleaning/.env

安装systemd服务:

sudo cp /myems-cleaning/myems-cleaning.service /lib/systemd/system/

启用服务:

sudo systemctl enable myems-cleaning.service

启动服务:

sudo systemctl start myems-cleaning.service

监控服务:

sudo systemctl status myems-cleaning.service

查看日志:

cat /myems-cleaning.log

第6步 myems-normalization

在此步骤中,您将安装myems-normalization服务。

sudo cp -r ~/myems/myems-normalization /myems-normalization
cd /myems-normalization
sudo pip install -r requirements.txt

将exmaple.ev文件复制到.env并修改.env文件:

sudo cp /myems-normalization/example.env /myems-normalization/.env
sudo nano /myems-normalization/.env

安装systemd服务

sudo cp /myems-normalization/myems-normalization.service /lib/systemd/system/

启用服务:

sudo systemctl enable myems-normalization.service

启动服务:

sudo systemctl start myems-normalization.service

监控服务:

sudo systemctl status myems-normalization.service

查看日志:

cat /myems-normalization.log

第7步 myems-aggregation

在此步骤中,您将安装myems-aggregation服务。

sudo cp -r ~/myems/myems-aggregation /myems-aggregation
cd /myems-aggregation
sudo pip install -r requirements.txt

将exmaple.ev文件复制到.env并修改.env文件:

sudo cp /myems-aggregation/example.env /myems-aggregation/.env
sudo nano /myems-aggregation/.env

安装systemd服务

sudo cp /myems-aggregation/myems-aggregation.service /lib/systemd/system/

启用服务:

sudo systemctl enable myems-aggregation.service

启动服务:

sudo systemctl start myems-aggregation.service

监控服务:

sudo systemctl status myems-aggregation.service

查看日志:

cat /myems-aggregation.log

第8步 myems-web

在此步骤中,您将安装myems-web服务。

sudo rm /etc/nginx/sites-enabled/default
sudo rm /etc/nginx/conf.d/default.conf

在目录 /etc/nginx/conf.d/ 下添加一个新文件

sudo nano /etc/nginx/conf.d/myems-web.conf

使用如下指令编写,如果myems-api服务托管在不同的服务器上,则使用实际的地址替换默认的myems-api地址http://127.0.0.1:8000/

server {
listen 80;
server_name myems-web;
location / {
root /var/www/myems-web;
index index.html index.htm;
# add try_files directive to avoid 404 error while refreshing pages
try_files $uri /index.html;
}
## To avoid CORS issue, use Nginx to proxy myems-api to path /api
## Add another location /api in 'server'
## replace the default myems-api url http://127.0.0.1:8000/ with actual url if the myems-api servcie hosted on different server
location /api {
proxy_pass http://127.0.0.1:8000/;
proxy_connect_timeout 75;
proxy_read_timeout 600;
send_timeout 600;
}
}
  • 安装 MyEMS Web UI:

修改配置文件:

备注

https://mapbox.com 获取 mapboxToken 然后设置 showOnlineMap 为 true. 如果要关闭在线地图功能,设置 showOnlineMap 为 false

cd ~/myems/myems-web
sudo nano src/config.js

编译:

sudo npm i --unsafe-perm=true --allow-root --legacy-peer-deps
sudo npm run build

安装: 注意,以下路径应该与nginx.conf中配置的路径相同。

sudo rm -r /var/www/myems-web
sudo mv build  /var/www/myems-web

将端口添加到防火墙:

sudo semanage port -a -t http_port_t  -p tcp 80
sudo firewall-cmd --zone=public --add-port=80/tcp --permanent
sudo firewall-cmd --reload

重启 NGINX

sudo systemctl restart nginx

提示

如果您遇到“500内部服务器错误”nginx错误,可以通过使用命令“sudo setforce 0”更改SELinx模式来修复它

安装后

祝贺您现在可以登录MyEMS Admin UI和Web UI。

默认端口

MyEMS Web UI: 80

MyEMS API: 8000

MyEMS Admin UI: 8001

假设服务器地址是 192.168.1.8 (替换为服务器真实地址) 访问MyEMS Web UI地址是 http://192.168.1.8 (80可以忽略) 访问MyEMS Admin UI地址是 http://192.168.1.8:8001

默认密码

MyEMS Admin UI

用户名:

administrator

密码:

!MyEMS1

MyEMS Web UI

用户名:

administrator

密码:

!MyEMS1

故障排除

MySQL 8.0安装

1. 准备工作

检查系统环境

# 查看系统版本
cat /etc/redhat-release

# 检查是否已安装MySQL
rpm -qa | grep mysql
rpm -qa | grep mariadb

# 如果存在mariadb,先卸载
rpm -e --nodeps mariadb-libs-*

2. 添加下载MySQL官方rpm包

https://cdn.mysql.com//Downloads/MySQL-8.0/mysql-8.0.45-1.el8.x86_64.rpm-bundle.tar

3. 安装MySQL 8.0

tar -xvf *.tar
yum localinstall *.rpm

# 如果遇到GPG密钥问题,可以临时使用
yum install -y mysql-community-server --nogpgcheck

4. 启动MySQL服务

# 启动MySQL服务
systemctl start mysqld

# 设置开机自启
systemctl enable mysqld

# 查看服务状态
systemctl status mysqld

5. 获取初始密码

# 查看MySQL生成的临时密码
grep 'temporary password' /var/log/mysqld.log

6. 安全配置

# 运行安全配置脚本
mysql_secure_installation

按提示操作:

  1. 输入临时密码
  2. 设置新密码(必须包含大小写字母、数字和特殊字符)
  3. 是否更改root密码?Y
  4. 是否移除匿名用户?Y
  5. 是否禁止root远程登录?根据需求选择
  6. 是否移除测试数据库?Y
  7. 是否重新加载权限表?Y

7. 登录MySQL验证

# 登录MySQL
mysql -u root -p

# 查看版本
SELECT VERSION();

# 查看数据库
SHOW DATABASES;

8. 配置字符集(可选)

编辑配置文件:

vi /etc/my.cnf

添加以下内容:

[client]
default-character-set=utf8mb4

[mysql]
default-character-set=utf8mb4

[mysqld]
character-set-server=utf8mb4
collation-server=utf8mb4_unicode_ci
init-connect='SET NAMES utf8mb4'


# 降低密码策略要求设置密码策略
validate_password.policy = LOW
validate_password.length = 6
validate_password.mixed_case_count = 0
validate_password.number_count = 0
validate_password.special_char_count = 0

重启服务:

systemctl restart mysqld

9. 防火墙设置

# 开启3306端口
firewall-cmd --permanent --add-port=3306/tcp
firewall-cmd --reload

# 或关闭防火墙(不推荐)
# systemctl stop firewalld
  1. 远程访问配置(可选)
-- 登录MySQL
mysql -u root -p

-- 创建远程访问用户
CREATE USER 'root'@'%' IDENTIFIED BY '!MyEMS1';
-- 修改root用户密码
ALTER USER 'root'@'%' IDENTIFIED BY '!MyEMS1';
-- 授予权限
GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' WITH GRANT OPTION;

-- 刷新权限
FLUSH PRIVILEGES;


常见问题解决

1. 内存不足错误

如果服务器内存较小,可以限制MySQL内存使用:

vi /etc/my.cnf
# 添加以下配置
innodb_buffer_pool_size = 256M
innodb_log_buffer_size = 16M
max_connections = 100

2. 启动失败排查

# 查看错误日志
tail -f /var/log/mysqld.log

# 查看端口占用
netstat -tlnp | grep 3306

3. 密码策略修改

-- 查看当前密码策略
SHOW VARIABLES LIKE 'validate_password%';

-- 修改密码策略(如果需要简单密码)
SET GLOBAL validate_password.policy = LOW;
SET GLOBAL validate_password.length = 6;

验证安装

# 检查MySQL服务
ps aux | grep mysql

# 检查端口
netstat -tlnp | grep 3306

# 检查MySQL版本
mysql --version