Operation

contents

  • 服务器
    • 一、相关概念
      • 1.1 云服务器与实例
      • 1.2 关于域名解析延时与80端口
      • 1.3 关于备案
      • 1.4 关于SSL证书
      • 1.5 关于SSL证书的签发
      • 1.6 关于SSL证书的部署
      • 1.7 关于LNMP和LAMP
      • 1.8 关于bt面板
    • 二、单服务器+单一级域名=多网站
      • 2.1 创建多个二级域名
      • 2.2 解析二级域名绑定到服务器上
      • 2.3 理解二级域名的访问
      • 2.4 实现不同的域名访问不同的文件
  • 部署flask
    • 一、远程连接服务器
    • 二、配置MySQL
      • 2.1 放通端口
      • 2.2 安装MySQL并启动
      • 2.3 配置MySQL
      • 2.4 更改config.py
      • 2.5 本地连接远程数据库
      • 2.6 本地构造数据库信息
    • 三、配置Nginx
      • 3.1 放通端口
      • 3.2 安装Nginx并启动
    • 四、配置python
      • 4.1 安装python
      • 4.2 安装python环境管理包
    • 五、项目相关
      • 5.1 创建py虚拟环境
      • 5.2 Git管理
      • 5.3 配置flask运行环境
      • 5.4 运行flask应用
        • 1 内测阶段
        • 2 公测阶段
      • 5.4 一些bug

服务器

一、相关概念

1.1 云服务器与实例

一个云服务器相当于一个抽象的类,在其中购买配置了指定的实例后相当于实例化一个类,从而一个云服务器对应一个实例

1.2 关于域名解析延时与80端口

在给购买好的域名进行解析的时候,即指向自己服务器的公网IP的时候,可能会有一段时间的延时。但其实可能是没有给云服务器放通80端口导致的

1.3 关于备案

首先需要清除的概念是,备案指的是给网站主机,也就是云服务器进行备案,而一般而言的域名备案其实就是给云服务器备案,只不过叫做域名备案很可能是因为大家在使用域名的时候才发现不备案是无法通过域名访问网站的。这是因为云服务器厂家做的设定,也只是顺应了政策的需求

当前的形式是,对于指向中国大陆 ip 的云服务器需要备案,如果指向的是非中国大陆的 ip,就不需要备案了。一般而言,中文的指向HK,英文的指向UK

1.4 关于SSL证书

http协议默认使用的是80端口,而申请了SSL证书后,通过https协议访问的网站默认使用的是443端口,因此需要提前在实例的安全组中,放通443端口

1.5 关于SSL证书的签发

  • 如果是基于bt面板操作的话。可以通过ssl选项中“Let’s Encrypt”的选项免费申请三个月的用量
  • 由于是基于bt面板管理,需要打开强制通过https进入这个选项,从而直接默认使用https协议访问网站
  • 如果想要通过官方渠道获取。可以在阿里云或者腾讯云等直接免费领取一定额度的ssl证书

1.6 关于SSL证书的部署

获得已签发的ssl证书后,下载下来,再通过bt面板进行部署

  1. 证书文件:pem 文件
  2. 密钥文件:key 文件
image-20230826104235878

1.7 关于LNMP和LAMP

  • LNMP是一组Linux操作系统下的Nginx、MySQL、PHP和Perl的组合安装包,常用于构建高性能的Web服务器。通过使用LNMP,可以快速搭建一个功能强大的网站系统
  • LAMP是指Linux、Apache、MySQL和PHP的组合,它是一个开源的Web开发平台。这个组合通常被用来构建高性能的Web应用程序

1.8 关于bt面板

简介:其实就是一个类windows的linux环境下的可视化管理工具

安装:服务器安装宝塔面板,基于不同的linux系统会有不同的指令,详情见宝塔面板安装地址,选择相应的指令进行安装即可

进入:通过bt指令进入服务器可视化管理界面

image-20231215190014294

管理:安装网站运行所需的环境,耗时如下:

image-20230826190642441

二、单服务器+单一级域名=多网站

参考:通过Nginx在一台服务器部署多个Web应用

2.1 创建多个二级域名

多个网站可以通过二级域名的形式只依赖一个一级域名,从而实现一个域名衍生出多个子域名的形式,即一级域名为 baidu.com,二级域名为 mcn.baidu.comcareer.baidu.com 等等

2.2 解析二级域名绑定到服务器上

每一个二级域名都需要解析到相应的IP地址,即主机记录对应记录值,才能进行后续的访问。其实可以理解为,将不同的二级域名都绑定到当前的服务器上,像这样:

image-20230826011106105

2.3 理解二级域名的访问

我们通过不同的二级域名访问网站时,其实就是访问不同的文件夹中的文件信息,像这样:

image-20230826011328462

2.4 实现不同的域名访问不同的文件

这时我们就需要配置 nginx 的代理服务器了, nginx 中的 nginx.conf 文件示例配置如下

##### example project #####
server {listen       443 ssl; # 监听的端口server_name  test.cn; # 监听的网址# ssl证书的相关文件路径ssl_certificate      /usr/local/nginx/ssl/test.cn_bundle.pem;ssl_certificate_key  /usr/local/nginx/ssl/test.cn.key;ssl_session_cache    shared:SSL:1m;ssl_session_timeout  5m;ssl_ciphers  HIGH:!aNULL:!MD5;ssl_prefer_server_ciphers  on;# 项目路径location / {proxy_pass https://localhost:8080/; # 转向“本地”8080端口# root path;  						# 根目录# index demo.html;  				# 设置默认页# proxy_pass  http://mysvr;  		# 请求转向 mysvr 定义的服务器列表# deny 127.0.0.1;  					# 拒绝的ip# allow 172.18.5.54; 				# 允许的ip       }
}

假如此时我们需要 docs.example.com 访问文档分站(静态),www.example.com 与 example.com 都访问主站(动态),我们就需要配置 nginx 中的 nginx.conf 文件,如下

#----- docs.example.com -----#
server {listen       443 ssl; 			# 监听的端口server_name  docs.example.com; 	# 监听的网址# ssl证书的相关文件路径ssl_certificate      /usr/local/nginx/ssl/test.cn_bundle.pem;ssl_certificate_key  /usr/local/nginx/ssl/test.cn.key;ssl_session_cache    shared:SSL:1m;ssl_session_timeout  5m;ssl_ciphers  HIGH:!aNULL:!MD5;ssl_prefer_server_ciphers  on;# 项目路径location / {root /usr/web/docs;  				# 根目录}
}#----- www.example.com -----#
server {listen       443 ssl; 			# 监听的端口server_name  www.example.com; 	# 监听的网址# ssl证书的相关文件路径ssl_certificate      /usr/local/nginx/ssl/b.test.cn_bundle.pem;ssl_certificate_key  /usr/local/nginx/ssl/b.test.cn.key;ssl_session_cache    shared:SSL:1m;ssl_session_timeout  5m;ssl_ciphers  HIGH:!aNULL:!MD5;ssl_prefer_server_ciphers  on;location / {root /usr/web/www;  				# 根目录}
}#----- example.com -----#
server {listen       443 ssl; 			# 监听的端口server_name  www.example.com; 	# 监听的网址# ssl证书的相关文件路径ssl_certificate      /usr/local/nginx/ssl/b.test.cn_bundle.pem;ssl_certificate_key  /usr/local/nginx/ssl/b.test.cn.key;ssl_session_cache    shared:SSL:1m;ssl_session_timeout  5m;ssl_ciphers  HIGH:!aNULL:!MD5;ssl_prefer_server_ciphers  on;location / {proxy_pass  https://www;  			# 请求转向 mysvr 定义的服务器列表}
}

部署flask

一、远程连接服务器

服务器信息

[root@DwjDemo1 ~]# cat /etc/os-releaseNAME="Alibaba Cloud Linux"								发行版的名称
VERSION="3 (Soaring Falcon)"							发行版的版本号
ID="alinux"												唯一的标识符
ID_LIKE="rhel fedora centos anolis"						一些类似的发行版
VERSION_ID="3"											发行版的版本编号
PLATFORM_ID="platform:al8"								平台的标识符
PRETTY_NAME="Alibaba Cloud Linux 3 (Soaring Falcon)"	可读的发行版名称和版本号
ANSI_COLOR="0;31"										ANSI终端输出的颜色: "0;31",通常用于表示错误或警告信息
HOME_URL="https://www.aliyun.com/"						发行版的官方网站链接

连接方法

  • 方法一:利用阿里云自带的服务器连接入口,远程连接服务器

  • 方法二:使用MobaXterm端口连接工具并更新全局软件

    yum update
    
  • 输入 username 和 password

二、配置MySQL

2.1 放通端口

服务器放通端口3306

2.2 安装MySQL并启动

参考:Linux安装mysql8.0(官方教程!)

2.3 配置MySQL

设置mysql登录密码

在服务器中连接mysql

mysql -uroot -p

授予权限给自己

# MySQL 5 版本
GRANT ALL ON *.* TO root@'%' IDENTIFIED BY '替换成你的root密码' WITH GRANT OPTION;# MySQL 8 版本
ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY '替换成你的root密码';

使用数据库

use mysql

允许远程登录数据库

update user set host = '%' where user = 'root';

刷新更新配置

FLUSH PRIVILEGES;

2.4 更改config.py

修改项目中 config.py 中的配置信息

# @Time   : 2023-12-03 23:25
# @File   : config.py
# @Author : Mr_Dwj'''
配置文件:1. 数据库配置信息2. ...
'''# 数据库的配置信息
HOSTNAME = ''
PORT = '3306'
DATABASE = 'test1'
USERNAME = ''
PASSWORD = ''
DB_URI = 'mysql+pymysql://{}:{}@{}:{}/{}?charset=utf8mb4'.format(USERNAME, PASSWORD, HOSTNAME, PORT, DATABASE)
SQLALCHEMY_DATABASE_URI = DB_URI

2.5 本地连接远程数据库

image-20231207232537233 image-20231207232615304

2.6 本地构造数据库信息

拷贝数据库表 - 直接在DataGrip中寻找进行复制即可

image-20231207232434015

三、配置Nginx

参考:Linux安装Nginx(超详细步骤)

3.1 放通端口

服务器放通80端口

3.2 安装Nginx并启动

进入nginx官网并下载稳定版至本地:image-20231208234403083

上传服务器(直接通过mobaxterm拖拽)并解压到当前目录下并进入nginx文件夹

tar -zxvf nginx-1.20.tar.gz
cd "/home/nginx-1.20/"

配置nginx并编译安装

# 配置configure 
# --prefix 代表安装的路径
# --with-http_ssl_module 安装ssl
# --with-http_stub_status_module 查看nginx的客户端状态
./configure --prefix=/usr/local/nginx-1.20 --with-http_ssl_module --with-http_stub_status_module# 编译安装
make && make install

进入sbin目录,启动nginx

# 启动nginx
./nginx

解决启动遇到的端口占用的问题

image-20231209001749320

killall -9 nginx 杀掉 nginx 的进程,然后重启


然后浏览器通过http的80端口访问公网ip,就可以看到欢呼雀跃的一幕

image-20231209001703919

四、配置python

4.1 安装python

参考:linux安装python

命令集合

# 安装python依赖
If you want a release build with all stable optimizations active (PGO, etc),please run ./configure --enable-optimizations# 本地下载拖拽上传至服务器,解压安装包
tar -xvf Python-3.11.tgz# 进入安装包,配置安装路径
cd Python-3.10.6
./configure --prefix=/usr/local/python311# 编译安装
make && make install# 将最新的python创建软链链接
ln -s /usr/local/python311/bin/python3.11 /usr/bin/python311# 修改yum依赖默认的python版本
vi /usr/libexec/urlgrabber-ext-down
vi /usr/bin/yum# 修改防火墙
vi /usr/bin/firewall-cmd
vi /usr/sbin/firewalld# 创建pip软连接
ln -s /usr/local/python311/bin/pip3.11 /usr/bin/pip311

vim的编辑指令

# 进入编辑模式
i# 退出编辑模式进入命令模式
Esc# 保存并关闭文件
:w# 退出vim编辑模式
:q

4.2 安装python环境管理包

安装python虚拟环境管理依赖

pip install virtualenvwrapper

配置虚拟环境

# 在根目录下进入.bashrc文件进行编辑
vi .bashrc
i# ctrl+f进入末尾,粘贴一下文字,保存并退出
export WORKON_HOME=$HOME/.virtualenvs
VIRTUALENVWRAPPER_PYTHON=/usr/bin/python311
source /usr/local/bin/virtualenvwrapper.sh# 刷新配置文件
source ~/.bashrc

刷新配置文件时报错:virtualenvwrapper.sh: There was a problem running the initialization hooks.

解决方案参考:virtualenvwrapper.sh报错: There was a problem running the initialization hooks.解决

五、项目相关

5.1 创建py虚拟环境

创建虚拟py环境

mkvirtualenv --python=/usr/bin/python311 <EnvName>

启动虚拟环境

workon <EnvName>

退出虚拟环境

deactivate

5.2 Git管理

进入python虚拟环境目录<EnvName>

初次部署:拉取远程源文件

git clone https://github.com/Explorer-Dong/YunJinWeb.git

后续更新:覆盖原始代码并重新运行应用

git pull
# 找到所有uwsgi进程
ps -ef|grep uwsgi
# 杀死所有进程
kill -9 <进程号>
# 退出uwsgi但是不停止服务的操作
uwsgi -d --ini uwsgi.ini

5.3 配置flask运行环境

检查本项目所需py模块

pip freeze >requirements.txt

安装所需py模块

pip install -r requirements.txt

5.4 运行flask应用

1 内测阶段

使用flask自带的服务器运行

运行flask主接口文件 app.py

python app.py

运行app.py时报错,端口已被占用,解决方案:

  • 方法一:换一个端口运行

  • 方法二:杀死其余的端口占用进程,重启应用

    # 检测端口占用 
    netstat -npl | grep "端口"# 查找占用端口的进程的PID
    sudo lsof -i:"端口"# 根据PID杀死该进程
    sudo kill -9 <PID>
    
2 公测阶段

使用uwsgi应用服务器运行

安装并配置uwsgi应用服务器

  • 安装uwsgi包

    pip install uwsgi
    
  • 创建uwsgi.ini文件并编辑

    touch uwsgi.ini
    
    [uwsgi]# -------------------- 路径相关的设置 --------------------# 项目的路径
    chdir           = /root/.virtualenvs/test111/demo/# Flask的uwsgi文件配对的应用
    wsgi-file       = /root/.virtualenvs/test111/demo/app.py# 回调的app对象
    callable        = app# Python虚拟环境的路径
    home            = /root/.virtualenvs/test111# -------------------- 进程相关的设置 --------------------# 主进程
    master          = true# 最大数量的工作进程
    processes       = 10# 监听5000端口(或监听socket文件,与nginx配合)
    http            = :5000 # socket监听
    # socket        = /srv/[项目名称]/[项目名称].sock# 设置socket的权限
    # chmod-socket    = 666# 退出的时候是否清理环境
    vacuum          = true
    
  • 通过uwsgi应用服务器运行flask应用

    uwsgi启动flask项目(venv虚拟环境)

    # 初始启动uwsgi指令
    uwsgi --ini uwsgi.ini
    
  • 退出uwsgi但是不停止服务的操作

    # 退出uwsgi但是不停止服务的操作
    uwsgi -d --ini uwsgi.ini# 此时想要停止就需要找到uwsgi的进程并全部杀死# 找到所有uwsgi进程ps -ef|grep uwsgi# 杀死所有进程kill -9 <进程号>
    

5.4 一些bug

问题一:读取json时出现问题

error: UnicodeDecodeError: ‘utf-8’ codec can’t decode byte 0xc3 in position 39: invalid continuation byte

reason: 对 string 解码时出现错误

solve:

将app.py中的

with open('static/json/image_text.json', 'r') as f:image_text = json.load(f)

改为

with open('static/json/image_text.json', 'r', encoding='gbk') as f:image_text = json.load(f)

参考:https://bobbyhadz.com/blog/python-unicodedecodeerror-utf-8-codec-cant-decode-byte

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/423508.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

GPT科研应用与AI绘图及论文高效写作

详情点击链接&#xff1a;GPT科研应用与AI绘图及论文高效写作 一OpenAI 1.最新大模型GPT-4 Turbo 2.最新发布的高级数据分析&#xff0c;AI画图&#xff0c;图像识别&#xff0c;文档API 3.GPT Store 4.从0到1创建自己的GPT应用 5. 模型Gemini以及大模型Claude2二定制自己…

Debezium发布历史83

原文地址&#xff1a; https://debezium.io/blog/2020/02/19/debezium-camel-integration/ 欢迎关注留言&#xff0c;我是收集整理小能手&#xff0c;工具翻译&#xff0c;仅供参考&#xff0c;笔芯笔芯. Debezium 和 Apache Camel 的集成场景 二月 19, 2020 作者&#xff1a…

【漏洞复现】Hikvision综合安防管理平台report文件上传漏洞

Nx01 产品简介 Hikvision&#xff08;海康威视&#xff09;是一家在中国颇具影响力的安防公司&#xff0c;其网络摄像头产品在市场上占据了相当大的份额。综合安防管理平台基于“统一软件技术架构”理念设计&#xff0c;采用业务组件化技术&#xff0c;满足平台在业务上的弹性扩…

联邦学习:密码学 + 机器学习 + 分布式 实现隐私计算,破解医学界数据孤岛的长期难题

联邦学习&#xff1a;密码学 机器学习 分布式 提出背景&#xff1a;数据不出本地&#xff0c;又能合力干大事联邦学习的问题联邦学习架构 分布式机器学习&#xff1a;解决大数据量处理的问题横向联邦学习&#xff1a;解决跨多个数据源学习的问题纵向联邦学习&#xff1a;解决…

基于XG24-EK2703A的BLE HID蓝牙键盘+鼠标复合设备功能开发(BLE+HID+FreeRTOS+Gecko SDK)

目录 项目介绍硬件介绍项目设计开发环境及工程参考总体流程图硬件基本配置应用初始化按键中断回调定时器回调按键响应任务蓝牙事件回调BLE HIDReport Map及报文键盘设备鼠标设备复合设备 发送字符串上/下滚动 功能展示项目总结 &#x1f449; 【Funpack3-1】基于XG24-EK2703A的…

Android 通过adb命令查看应用流量

一. 获取应用pid号 通过adb shell ps -A | grep 包名 来获取app的 pid号 二. 查看应用流量情况 使用adb shell cat /proc/#pid#/net/dev 命令 来获取流量数据 备注&#xff1a; Recevice: 表示收包 Transmit: 表示发包 bytes: 表示收发的字节数 packets: 表示收发正确的…

服务器感染了.wis[[Rast@airmail.cc]].wis勒索病毒,如何确保数据文件完整恢复?

导言&#xff1a; 在当今数字化的时代&#xff0c;恶意软件攻击已经变得越来越复杂和狡猾&#xff0c;[[MyFilewaifu.club]].wis [[backupwaifu.club]].wis[[Rastairmail.cc]].wis勒索病毒是其中的一种新威胁。本文91数据恢复将深入介绍[[MyFilewaifu.club]].wis [[backupwaif…

windows11上安装虚拟机VMware

1、安装虚拟机&#xff08;待补充&#xff09; 第二步&#xff1a;安装VMware tools 实现windows文件上传到虚拟机中 1、安装好虚拟机后&#xff0c;查看虚拟机ip用Xshell连接虚拟机&#xff0c;并安装VMware tools(只有安装了VMware tools才能实现虚拟机和本机的文件共享。在…

爬虫安居客新房

一、首先看网址 后面有全部代码 https://hf.fang.anjuke.com/loupan/baohequ/p3 这种形式很好分析&#xff0c;https://hf.fang.anjuke.com/loupan/行政区域页码 xinfang_area ["feixixian", "baohequ", "shushanqu", "luyangqu",…

web3:B站chainlink课程第五课Wsl安装ubuntu虚拟机

坑了我好久。 https://learn.microsoft.com/zh-cn/windows/wsl/install-manual 按照微软给的这个手动安装的方式来&#xff0c;别想在线了&#xff0c;反正来看这个的肯定是直接 wsl --install成功不了的选手。 注意&#xff01; 步骤6别从Microsoft Store 下载&#xff0c;…

2024年第十二届亚洲机械与材料工程国际会议(ACMME 2024)即将召开!

时间&#xff1a;2024年6月14-17日 地点&#xff1a;日本京都先端科学大学太秦校区 会议官网&#xff1a;第11届ACMME |日本京都 2024年第十二届亚洲机械与材料工程会议 &#xff08;ACMME 2024&#xff09;将于2024年6月14日-17日在日本京都先端科学大学召开。亚洲机械与材料…

C语言——结构体讲解

目录 一、结构体类型的声明 二、结构体变量的定义和初始化 三、结构体的重命名 四、结构体的自引用 五、结构体内存对齐 六、结构体传参 七、结构体实现位段 7.1 什么是位段 7.2 位段的声明和使用 7.3 位段的空间大小计算 7.4 位段的内存分配 7.5 位段的跨平…