之前完成了贴吧签到系统的搭建,笔者想将这个功能分享给更多人使用,所以尝试搭建了一个网页,一路遇到了很多问题,最终解决了,记录下过程分享给大家

首先安装 uWSGI ,和 Nginx 配套使用,具体用途自行查阅(已配置Python3环境)



pip3 install uwsgi



新建一个 uWSGI 的配置文件,路径自选,笔者配置文件路径为 /root/uwsgi.ini ,项目路径为 /root/flask ,配置文件内容如下



[uwsgi]
socket = 127.0.0.1:8000 
processes = 4   
threads = 2 
master = true
pythonpath = /root/flask
module = manage
callable = app
memory-report = true



其中需要修改的是 callable 名,即 app = Flask(__name__) 名字,一般是 app ,笔者含有这行代码的文件名为 manage.py ,所以 module 名为 manage ,socket 最后的8000需要记下,后面配置 Nginx 需要,这个值可以修改成自己需要的

如果已经运行过 uWSGI,可以先杀掉进程



killall -9 uwsgi



然后启动 uWSGI



uwsgi --ini /root/uwsgi.ini -d /root/uwsgi.log



不要使用 uWSGI -x 命令,一般此命令使用的是 xml 配置文件,如果要用此命令,则需要安装



yum install libxml*



然后重新安装 uWSGI 即可

使用yum安装 Nginx



sudo yum install epel-release
sudo yum install nginx



使用systemctl控制Nnginx



systemctl start nginx
systemctl restart nginx
systemctl enable nginx 设置开机启动
killall -9 nginx



然后打开Nginx配置文件,路径一般为



/etc/nginx/nginx.conf



也可以使用以下命令查找路径



find / -name nginx.conf



 编辑配置文件,可以使用vim或者使用ftp软件,笔者使用的是WinSCP,因为后文需要将本地的项目传到VPS服务器,找到下文中位置(http段内),添加红色的两句,地址填写上文uWSGI里的地址,如果在 Flask 中配置了错误页面的路由,则不用修改这里的其他内容



location / {
    include uwsgi_params;
    uwsgi_pass 127.0.0.1:8000;
    root  html;
    index  index.html index.htm;
}



修改防火墙配置,允许HTTP和HTTPS通信

 



sudo firewall-cmd --permanent --zone=public --add-service=http 
sudo firewall-cmd --permanent --zone=public --add-service=https
sudo firewall-cmd --reload



 

然后用上文的命令重启Nginx服务

 

之后就是配置Flask项目相关的库,如果有 requirements.txt 文件,可以直接使用以下命令安装所有依赖包,如没有则需手动安装



pip3 install -r /root/flask/requirements.txt



笔者使用的是 MySQL ,所以也记录下 MySQL 的安装过程

下载解压安装 MySQL



wget http://repo.mysql.com/mysql57-community-release-el7-10.noarch.rpm
rpm -Uvh mysql57-community-release-el7-10.noarch.rpm
yum install  -y  mysql-community-server



启动 MySQL 服务,(CentOS7 已经用 systemctl 指令替代了原来的 service 命令)



systemctl start mysqld.service



新版MySQL安装后又默认密码,密码储存在 /var/log/mysqld.log 中,可以直接使用查找命令获得



grep 'temporary password' /var/log/mysqld.log



然后使用默认密码登陆,-p 为带密码登陆,回车后再输入密码



mysql -u root -p



然后修改密码强度保护



set global validate_password_policy=0;
set global validate_password_length=1;



然后再修改密码(红色部分为你的密码)



ALTER USER 'root'@'localhost' IDENTIFIED BY 'yourpassword';



就可以正常使用了,退出 MySQL 界面使用 exit 命令

但是 Flask 项目使用 MySQL 时还需要安装 mysqlclient 库(如果使用 pymysql 之类的第三方库就不需要,使用 Flask 自带的 Flask-SQLAlchemy则需要)



yum install mysql-devel
yum install gcc python-devel
pip install mysqlclient



MySQL 配置大致如此,然后通过 WinSCP 等 sftp 软件传输到 vps 服务器即可

至此,大部分功能就能够正常实现了,如果你已经购买了域名,笔者使用的是阿里云,购买了域名和一年的云解析服务,然后配置云解析目标地址为服务器地址,记录类型为A,域名为 *.你的域名 即可,接下来就可以尝试打开你的网站了(初步设置完域名解析可能要一段时间才能访问)

如果一切顺利,现在就能显示你的网站了,如果出现问题,可以通过以下途径查看问题所在

直接运行 Flask 项目,查看是否是库安装的问题



python3 manage.py



如果已经访问过网站,可以在 Nginx 和 uWSGI 的日志里面查看问题



/root/uwsgi.log
/usr/local/nginx/log/



如果已经能访问网站,操作数据库时出现问题,可以查看数据库的日志



/var/log/mysqld.log



基本能通过日志发现问题,解决方法请自行搜索报错内容

如果是安装过程中出现问题,则可以清理完再重新安装,搜索安装过的软件和文件,先卸载软件再删除参留文件(以 MySQL 为例)



yum remove mysql mysql-server mysql-libs mysql-server;



如果是 yum 安装的则用 yum 卸载,用 pip 安装的用 pip卸载



rpm -qa | grep -i mysql
rpm 查找到的软件用 yum remove 卸载,因为依赖问题无法卸载可以使用 rpm -e --nodeps卸载,安装时不要使用 --nodeps 跳过依赖检查
find / -name mysql



find 查找到的文件用 rm -rf 删除(记得验证是否是正确的路径)



chkconfig --list | grep -i mysql



删除相关的服务 chkconfig --del mysql



卸载完之后再查找一遍,若清理干净则可以重新安装,可同理卸载 Nginx 和 uWSGI

理论上网页已经能正常运行在VPS上了,如果还出现其他问题,读者可以自行尝试解决并留言写下解决方法

 

在此感谢以下Geeks