最简单的部署 Python 项目操作,部署比较简单这块也不做详细描述了。基本上都是常规命令~~
这些东西基本上都可以灵活运用到其他地方,不仅仅只适用于此项目~~
# 1 更换 Centos 源
由于系统默认使用国外的源更新软件时太慢,所以更换为国内的更新源。
阿里云的源
1 [root@localhost ~]# wget -O /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-7.repo
网易云的源
1 2 [root@localhost ~]# wget -O /etc/yum.repos.d/CentOS-Base.repo http://mirrors.163.com/.help/CentOS7-Base-163.repo [root@localhost ~]# yum makecache
# 2 Python3 配置
# 2.1 安装 Python3
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 # 下载Python3.7 [root@localhost ~]# wget https://www.python.org/ftp/python/3.7.0/Python-3.7.0.tar.xz # 解压 [root@localhost ~]# tar -xvf Python-3.7.0.tar.xz [root@localhost ~]# cd Python-3.7.0 # 更新 [root@localhost ~]# yum update -y # 安装Python3.7的依赖 [root@localhost ~]# yum install zlib-devel bzip2-devel openssl-devel ncurses-devel sqlite-devel readline-devel tk-devel libffi-devel gcc make # 将python安装到/usr/local/python3 [root@localhost ~]# ./configure --prefix=/usr/local/python3 # 编译并安装 [root@localhost ~]# make && make install # 建立python3软连接 [root@localhost ~]# ln -s /usr/local/python3/bin/python3 /usr/bin/python3 # 建立pip3软连接 [root@localhost ~]# ln -s /usr/local/python3/bin/pip3.7 /usr/bin/pip3 # 更新升级pip3 [root@localhost ~]# pip3 install --upgrade pip -i https://pypi.tuna.tsinghua.edu.cn/simple # 将/usr/local/python3/bin加入PATH [root@localhost ~]# vi /etc/profile # 在文件末尾添加 export PATH=$PATH:/usr/local/python3/bin # 环境变量在配置信息中生效 [root@localhost ~]# source /etc/profile
# 2.2 Python3.x 设置默认
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 # 修改yum配置 [root@localhost ~]# vi /usr/bin/yum 将第一行 #! /usr/bin/python 修改为#! /usr/bin/python2 # 修改urlgrabber-ext-down配置 [root@localhost ~]# vi /usr/libexec/urlgrabber-ext-down 将第一行 #! /usr/bin/python 修改为#! /usr/bin/python2 # 删除原有的软连接 [root@localhost ~]# rm -rf /usr/bin/python # 建立新的软连接 [root@localhost ~]# ln -s /usr/local/python3/bin/python3 /usr/bin/python # 查看版本 [root@localhost ~]# python Python 3.7.0 (default, Jan 23 2021, 02:55:09) [GCC 4.8.5 20150623 (Red Hat 4.8.5-44)] on linux Type "help", "copyright", "credits" or "license" for more information. > >> # 修改pip软连接 [root@localhost ~]# rm -rf /usr/bin/pip # 建立新的pip软连接 [root@localhost ~]# ln -s /usr/bin/pip3 /usr/bin/pip # 安装uWSGI服务 [root@localhost ~]# pip install uWSGI==2.0.18 # 建立新的uwsgi软连接(下面自启脚本会用到) [root@localhost ~]# ln -s /usr/local/python3/bin/uwsgi /usr/bin/uwsgi
# 2.3 安装 docker-compose
1 2 3 4 5 6 7 8 9 # 安装docker-compose [root@localhost ~]# curl -L https://github.com/docker/compose/releases/download/1.26.0/docker-compose-`uname -s`-`uname -m` -o /usr/local/bin/docker-compose [root@localhost ~]# chmod +x /usr/local/bin/docker-compose [root@localhost ~]# ln -s /usr/local/bin/docker-compose /usr/bin/docker-compose # 安装依赖工具bash-complete [root@localhost ~]# yum install -y bash-completion [root@localhost ~]# source /usr/share/bash-completion/completions/docker [root@localhost ~]# source /usr/share/bash-completion/bash_completion
# 3 uwsgi 开机自启服务
创建 hexo-blog-admin.service [Centos 服务脚本] 文件,按下面操作即可。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 # 1.进入脚本目录 [root@localhost ~]# cd /lib/systemd/system/ # 2.创建脚本 [root@localhost ~]# vi hexo-blog-admin.service # 虚线表示文件中的配置 ------------------------------------------------------------------------------------------------ [Unit] # 脚本描述 Description=hexo-blog-admin After=syslog.target network.target remote-fs.target nss-lookup.target [Service] Type=forking # 启动uwsgi(/home/lmay/services/blog/hexo-blog-admin/hexo-blog-admin.ini 脚本根据自己实际位置调整) ExecStart=/usr/bin/uwsgi -d --ini /home/lmay/services/blog/hexo-blog-admin/hexo-blog-admin.ini # 停止uwsgi ExecStop=killall -9 uwsgi Restart=always PrivateTmp=true [Install] WantedBy=multi-user.target ------------------------------------------------------------------------------------------------ # 3.设置脚本开机自启 [root@localhost ~]# systemctl enable hexo-blog-admin.service # 4.常用命令 重新加载service文件: systemctl daemon-reload 启动一个服务:systemctl start xxx.service 关闭一个服务:systemctl stop xxx.service 重启一个服务:systemctl restart xxx.service 显示一个服务的状态:systemctl status xxx.service 在开机时启用一个服务:systemctl enable xxx.service 在开机时禁用一个服务:systemctl disable xxx.service 查看服务是否开机启动:systemctl is-enabled xxx.service 查看已启动的服务列表:systemctl list-unit-files|grep enabled 查看启动失败的服务列表:systemctl --failed
# 4 项目依赖 (Docker)
docker 更简单了,脚本基本上已经写好。一键执行即可~~
因为直接把写好的 init.sh 复制到 Linux 下,不知道为啥不能正常执行。故直接手动在 Linux 中创建一个 init.sh 脚本,然后把写好的命令直接复制过去即可。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 # 创建脚本 [root@localhost ~]# vi init.sh # 脚本授权 [root@localhost ~]# chmod 777 init.sh # 查看文件 [root@nacos blog]# ll total 24 # 自动部署脚本 -rwxrwxrwx 1 root root 1978 Jan 23 03:07 init.sh # 核心文件(直接复制过来即可) -rw-r--r-- 1 root root 2095 Jan 23 03:05 docker-compose.yml # 项目放置,随心所欲(项目中的一些配置,根据自己实际情况调整) drwxr-xr-x 7 root root 4096 Jan 23 04:36 hexo-blog-admin # 部署依赖服务 [root@nacos blog]# ./init.sh # # Docker Compose Shell Script # Blog: www.lmaye.com # Email: lmay@lmaye.com # ---> create [nginx] directory start. ---> create [minio] directory start. ---> create [mongo] directory start. ===> create directory success. ---> move [nginx] config file start. ./init.sh: line 48: [: too many arguments ===> move config files success. > >>>>>>>>>>>>>>>>> The End <<<<<<<<<<<<<<<<<< ==================> Docker deploy Start <================== Creating network "blog_default" with the default driver Pulling nginx (nginx:1.16)... ... ... ... # 等执行完成即可
# 5 Docker Nginx 代理宿主机服务
安装 Docker 时会在宿主机安装一个虚拟网关 docker0
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 # 查询docker0的IP地址 [root@localhost ~]# ip addr show docker0 3: docker0: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue state UP group default link/ether 02:42:55:33:a8:24 brd ff:ff:ff:ff:ff:ff inet 172.17.0.1/16 brd 172.17.255.255 scope global docker0 valid_lft forever preferred_lft forever # 配置docker上安装的nginx server { listen 80; server_name www.lmaye.com; location / { # 设置最大允许上传单个的文件大小 client_max_body_size 100m; proxy_redirect off; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; # 反向代理到宿主机服务 proxy_pass http://172.17.0.1:8080; } }
# 6 源码地址
本项目开源,仅供学习参考与个人使用!如有更好的方案和 idea,欢迎互相交流!如您觉得该项目对您有所帮助,欢迎点击右上方的 Star 标记,给予支持!!!谢谢~~ 如果有更好的 idea 也欢迎互相交流,联系方式博客菜单 about
注:项目已升级文件存储可切换 MinIO,MinIO 更简便、自带文件管理端。之前的 FastDFS 方式依然支持~~
Hexo Blog Admin 源码地址