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-release

NAME="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

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

夜视成像应用激光照明方法

在夜视成像领域&#xff0c;激光照明的使用主要集中在提高成像质量和远距离观察上。 以下是几种用于夜视成像的激光照明方法&#xff1a; 直接激光照明&#xff1a; 这种方法涉及直接用激光光束照射目标。激光器发出的光束可以是可见光或红外光&#xff0c;具体取决于应用需求和…

day01 深度学习介绍

目录 1.1深度学习介绍 1.2神经网络NN 1、概念&#xff1a; 2、神经元 3、&#xff08;单层&#xff09;神经网络 4、感知机&#xff08;两层&#xff09; 5、多层神经网络 6、激活函数 &#xff08;1&#xff09;饱和与非饱和激活函数 &#xff08;2&#xff09;饱和激活…

项目工时统计成本核算管理

技术架构: Java 1.8 MySQL 8 Vue 项目基于前后端分离架构&#xff0c;服务端主要技术&#xff1a;SpringBoot 前端主要是Vue。 项目介绍&#xff1a; 轻量级项目工时统计系统&#xff0c;是目前企业进行项工时管理统计的推荐选择。 通过项目工时管理系统&#xff0c;可通过…

Linux--文件链接

目录 1.建立软连接 2.建立硬链接 3.什么是软链接 Linux中软链接的应用场景 4.什么是硬链接 5.文件与目录的硬链接数 6.软链接与硬链接的区别 用户无法对目录建立硬链接&#xff0c;可以建立软连接。 在Linux中文件的链接有两种&#xff1a;1.软连接 2.硬链接 1.建立软…

Docker 配置 Gitea + Drone 搭建 CI/CD 平台

Docker 配置 Gitea Drone 搭建 CI/CD 平台 配置 Gitea 服务器来管理项目版本 本文的IP地址是为了方便理解随便打的&#xff0c;不要乱点 首先使用 docker 搭建 Gitea 服务器&#xff0c;用于管理代码版本&#xff0c;数据库选择mysql Gitea 服务器的 docker-compose.yml 配…

RK3568 移植Ubuntu

使用ubuntu-base构建根文件系统 1、到ubuntu官网获取 ubuntu-base-18.04.5-base-arm64.tar.gz Ubuntu Base 18.04.5 LTS (Bionic Beaver) 2、将获取的文件拷贝到ubuntu虚拟机,新建目录,并解压 mkdir ubuntu_rootfs sudo tar -xpf u

用flinkcdc debezium来捕获数据库的删除内容

我在用flinkcdc把数据从sqlserver写到doris 正常情况下sqlserver有删除数据&#xff0c;doris是能捕获到并很快同步删除的。 但是我现在情况是doris做为数仓&#xff0c;数据写到ods&#xff0c;ods的数据还会通过flink计算后写入dwd层&#xff0c;所以此时ods的数据是删除了…

SPN 泄露 | 扫描 | 维护

SPN 泄露 当Service Principal Names&#xff08;SPNs&#xff09;泄露时&#xff0c;可能会引发严重的安全风险&#xff0c;特别是在使用Kerberos身份验证的环境中。 身份欺骗&#xff08;Identity Spoofing&#xff09;&#xff1a; 攻击者可以用泄露的SPN来伪装成合法的服…

芯驰E3340软件编译以及更新步骤

打开已有工程File->Open Solution: 东南项目&#xff1a;e3340\boards\e3_324_ref_display\proj\jetour-t1n-fl3\sf\SES 编译&#xff1a;build->build sf 增加头文件和宏定义&#xff1a; 编译完成sf后&#xff0c;进行编译bootloader 东南项目&#xff1a;e3340\boa…

Java Server-Sent Events通信

Server-Sent Events特点与优势 后端可以向前端发送信息&#xff0c;类似于websocket&#xff0c;但是websocket是双向通信&#xff0c;但是sse为单向通信&#xff0c;服务器只能向客户端发送文本信息&#xff0c;效率比websocket高。 单向通信&#xff1a;SSE只支持服务器到客…

go语言(十四)----反射

变量的结构 2 举个例子 package mainimport "fmt"type Reader interface {ReadBook() }type Writer interface {WriteBook() }//具体类型 type Book struct {}func (this *Book) ReadBook() {fmt.Println("Read a Book")}func (this *Book) WriteBook() {…

​《WebKit 技术内幕》学习之九(3): JavaScript引擎

3 JavaScriptCore引擎 3.1 原理 JavaScriptCore引擎是WebKit中的默认JavaScript引擎&#xff0c;也是苹果在开源WebKit项目之后&#xff0c;开源的另外一个重要的项目。同其他很多引擎一样&#xff0c;在刚开始的时候它的主要部分是一个基于抽象语法树的解释器&#xff0c;这…

天软特色因子看板 (2024.1 第8期)

该因子看板跟踪天软特色因子A04001(当日趋势强度&#xff0c;该因子为反映股价走势趋势强弱&#xff0c;用以刻画股价走势趋势强弱&#xff0c;abs(值)越接近1&#xff0c;趋势 性越强&#xff0c;符号代表涨跌方向。 今日为该因子跟踪第8期&#xff0c;跟踪其在SW801080 (申万…

什么是WAF

WAF是Web应用防火墙&#xff08;Web Application Firewall&#xff09;的简称&#xff0c;是一款通过执行一系列针对HTTP/HTTPS的安全策略来专门为Web应用提供保护的产品。 WAF主要用于防御Web应用攻击&#xff0c;例如SQL注入、跨站脚本攻击&#xff08;XSS&#xff09;、网页…

Java--接口

文章目录 主要内容一.teacher&student1.源代码代码如下&#xff08;示例&#xff09;: 2.结果 二.shape1.源代码代码如下&#xff08;示例&#xff09;: 2.结果 三.生物、动物、人1.源代码代码如下&#xff08;示例&#xff09;: 2.结果 总结 主要内容 一.teacher&stu…

开源项目CuteSqlite开发笔记(八):Windows 64位/32位使用GetWindowLongPtr钩子函数

需求描述 在开发CuteSqlite的时候&#xff0c; 有一个功能需要实现&#xff0c;鼠标移到WTL::CStatic上后&#xff0c;发送消息通知CToolTipCtrl弹出。 遇到问题 WTL::CStatic控件没有相应 WM_MOUSEMOVE 消息&#xff0c;需要返回一个HTCLIENT消息来让窗口处理函数执行 WM_MO…

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

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

C#winform上位机开发学习笔记9-串口助手的多窗体功能添加

1.功能描述 涉及子窗体的创建过程&#xff0c;子窗体的调用操作&#xff0c;子窗体与主窗体的显示位置设置&#xff0c;子窗体随主窗体移动 2.代码部分 步骤1&#xff1a;新建button并修改Text 步骤2&#xff1a;在现工程中新建项目 步骤3&#xff1a;选择窗体修改窗体名称 …

SCCB接口

文章目录 概述引脚传输时序起始/结束信号三线模式两线模式 传输周期3阶段写传输周期2阶段写传输周期2阶段读传输周期阶段一 ID Address阶段二 子地址/读数据阶段三 写数据 SCCB与IIC区别未完待续(还有代码&#xff09;... 概述 SCCB&#xff08;Serial Camera Control Bus&…

【极数系列】Flink 初相识(01)

# 【极数系列】Flink 初相识&#xff08;01&#xff09; 引言 Flink官网&#xff1a;https://flink.apache.org/ Flink版本&#xff1a;https://flink.apache.org/blog/ Flink文档&#xff1a;https://ci.apache.org/projects/flink/flink-docs-release-1.12/ Flink代码库…