[toc]
spug安装
关于Spug
Spug
面向中小型企业设计的轻量级无 Agent 的自动化运维平台,整合了主机管理、主机批量执行、主机在线终端、文件在线上传下载、应用发布部署、在线任务计划、配置中心、监控、报警等一系列功能。
特性
- 批量执行: 主机命令在线批量执行
- 在线终端: 主机支持浏览器在线终端登录
- 文件管理: 主机文件在线上传下载
- 任务计划: 灵活的在线任务计划
- 发布部署: 支持自定义发布部署流程
- 配置中心: 支持 KV、文本、json 等格式的配置
- 监控中心: 支持站点、端口、进程、自定义等监控
- 报警中心: 支持短信、邮件、钉钉、微信等报警方式
- 优雅美观: 基于 Ant Design 的 UI 界面
- 开源免费: 前后端代码完全开源
1.docker安装
1.1 安装docker
1.1.1 下载二进制包
wget https://download.docker.com/linux/static/stable/x86_64/docker-20.10.2.tgz
1.1.2 解压缩并拷贝文件
tar xf docker-20.10.2.tgz && cp docker/* /usr/bin
1.1.3 使用systemd管理docker
Control Docker with systemd 官方文档关于使用systemd管理docker的说明
如果你是使用二进制方式安装的 docker,那么你也许需要整合 docker 到 systemd 中去。为了完成这个任务,你需要安装两个单元文件(service 和 socket)到 /etc/systemd/system 中去
Manually create the systemd unit files
When installing the binary without a package, you may want to integrate Docker with systemd. For this, install the two unit files (
service
andsocket
) from the github repository to/etc/systemd/system
.
⚠️需要下载的是docker.service.rpm
和docker.socket
这两个文件,需要把docker.service.rpm
重命名为docker.service
,然后再移动到/etc/systemd/system
下
wget https://github.com/moby/moby/raw/branch/branch/master/contrib/init/systemd/docker.service.rpm
wget https://github.com/moby/moby/raw/branch/branch/master/contrib/init/systemd/docker.socket
这里我们直接向文件写入内容
docker.service
cat > /etc/systemd/system/docker.service <<'EOF'
[Unit]
Description=Docker Application Container Engine
Documentation=https://docs.docker.com
After=network-online.target firewalld.service
Wants=network-online.target
[Service]
Type=notify
# the default is not to use systemd for cgroups because the delegate issues still
# exists and systemd currently does not support the cgroup feature set required
# for containers run by docker
ExecStart=/usr/bin/dockerd
ExecReload=/bin/kill -s HUP $MAINPID
# Having non-zero Limit*s causes performance problems due to accounting overhead
# in the kernel. We recommend using cgroups to do container-local accounting.
LimitNOFILE=infinity
LimitNPROC=infinity
LimitCORE=infinity
# Uncomment TasksMax if your systemd version supports it.
# Only systemd 226 and above support this version.
#TasksMax=infinity
TimeoutStartSec=0
# set delegate yes so that systemd does not reset the cgroups of docker containers
Delegate=yes
# kill only the docker process, not all processes in the cgroup
KillMode=process
# restart the docker process if it exits prematurely
Restart=on-failure
StartLimitBurst=3
StartLimitInterval=60s
[Install]
WantedBy=multi-user.target
EOF
docker.socket
cat >/etc/systemd/system/docker.socket<<EOF
[Unit]
Description=Docker Socket for the API
[Socket]
# If /var/run is not implemented as a symlink to /run, you may need to
# specify ListenStream=/var/run/docker.sock instead.
ListenStream=/run/docker.sock
SocketMode=0660
SocketUser=root
SocketGroup=docker
[Install]
WantedBy=sockets.target
EOF
linux中 /etc/systemd/system
和 /usr/lib/systemd/system
的区别
每一个 Unit(服务等) 都有一个配置文件,告诉 Systemd 怎么启动这个 Unit 。
Systemd 默认从目录 /etc/systemd/system/
读取配置文件。
但是,里面存放的大部分文件都是符号链接,指向目录 /usr/lib/systemd/system/
,真正的配置文件存放在那个目录。 systemctl enable
命令用于在上面两个目录之间,建立符号链接关系。
sudo systemctl enable clamd@scan.service
# 等同于
sudo ln -s '/usr/lib/systemd/system/clamd@scan.service' '/etc/systemd/system/multi-user.target.wants/clamd@scan.service'
1.1.4 重新加载服务并启动docker
systemctl daemon-reload
systemctl start docker && systemctl enable docker
1.1.5 配置阿里云加速
cat > /etc/docker/daemon.json <<-'EOF'
{
"registry-mirrors": ["https://gqk8w9va.mirror.aliyuncs.com"]
}
EOF
systemctl restart docker
1.2 安装spug
1.2.1 启动容器
Docker镜像内部使用的 Mysql
数据库。
如果需要持久化存储代码和数据,可以添加:-v 映射容器内/data路径
docker run \
-d \
--restart=always \
--name=spug \
-p 8000:80 \
-v /mydata/:/data \
registry.aliyuncs.com/openspug/spug
1.2.2 初始化
以下操作会创建一个用户名为 admin
密码为 spug.dev
的管理员账户,可自行替换管理员账户。
# 初始化管理员账户
docker exec spug init_spug admin spug.dev
# 执行完毕后需要重启容器
docker restart spug
1.3 使用nginx反向代理spug
http配置
server {
listen 80;
server_name spug.test.com;
location / {
proxy_pass http://127.0.0.1:8000;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
}
location ^~ /api/ws/ {
proxy_pass http://127.0.0.1:8000;
proxy_http_version 1.1;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection "Upgrade";
proxy_set_header X-Real-IP $remote_addr;
}
error_page 404 /index.html;
access_log /var/log/spug/spug.test.com.access.log;
error_log /var/log/spug/spug.test.com.error.log;
}
https配置
server {
listen 80;
server_name spug.test.com;
return 301 https://$server_name$request_uri;
client_max_body_size 1000m;
}
server {
listen 443 ssl;
server_name spug.test.com;
location / {
proxy_pass http://127.0.0.1:8000;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
}
location ^~ /api/ws/ {
proxy_pass http://127.0.0.1:8000;
proxy_http_version 1.1;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection "Upgrade";
proxy_set_header X-Real-IP $remote_addr;
}
error_page 404 /index.html;
access_log /var/log/spug/spug.test.com.access.log;
error_log /var/log/spug/spug.test.com.error.log;
ssl_certificate ssl_key/spug/1_spug.test.com_bundle.crt;
ssl_certificate_key ssl_key/spug/2_spug.test.com.key;
ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
}
浏览器访问
用户名:admin
密码:spug.dev
1.4 关于nginx配置遇到的问题
问题一:主机console连接空白
原因:
这种情况大部分都是
Websocket
连接建立失败了,一般出现在部署时自己加了一层 nginx 之类的代理工具,这些代理工具默认无法处理Weboscket
请求, 这就需要你配置其支持转发Websocket
请求
解决方法:
在nginx中配置如下内容
location ^~ /api/ws/ {
proxy_pass http://127.0.0.1:8000;
proxy_http_version 1.1;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection "Upgrade";
proxy_set_header X-Real-IP $remote_addr;
}
问题二:无法获取客户端真实IP以及spug console无法连接
在宿主机nginx中如果不配置
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
在登陆spug的时候就会提示无法获取客户端真实IP,但是配置了proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
后可以获取客户端真实IP,然而确无法连接主机console
原因:
spug容器中已经有一层nginx做代理了
解决方法:
注释spug容器中nginx配置文件
/etc/nginx/nginx.conf
中location ^~ /api/ws/
下的proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;