本章知识点
1、Centos下python3环境的部署 2、Python uwsgi 3、Python uwsgi+nginx部署 4、mysql主从备份介绍 5、Linux下的mysql安装 6、基于mysql的Django读写分离
知识点讲解 1、Centos下python3环境的部署 Yum源,就是我们的安装源。 检测yum是否完好 Yum list 当遇到以下问题 Yum 进程没有关闭 错误:1 Yum 源没有配置
data:image/s3,"s3://crabby-images/10844/1084445775ebf59ff053a52ed9b66275970b219e" alt=""
配置yum源: https://www.linuxidc.com/Linux/2017-08/146364.htm 错误:2 Pid 进程id
data:image/s3,"s3://crabby-images/623cf/623cfbd4574d0e24e0b51682c19ea063e93c672b" alt=""
Kill -9 pid 杀死进程
data:image/s3,"s3://crabby-images/a7237/a723757a7bf139369e74fe26e8b6d67d352c6c53" alt=""
data:image/s3,"s3://crabby-images/41d0a/41d0ab912ddbf6f70b5fac57c17a83cd3b28d1ec" alt=""
安装python需要的依赖包 Yum -y install zlib-devel bzip2-devel openssl-devel ncurses-devel sqlite-devel readline-devel tk-devel gcc make
data:image/s3,"s3://crabby-images/ac71b/ac71bd9535040a0a5d4d6b162fafb5041c3cb714" alt=""
data:image/s3,"s3://crabby-images/dad7e/dad7e2b043b3e34b92d7e2c944d2eea80e2a3a51" alt=""
Unix系统默认安装了python Centos 6 安装 python2.6版本 Centos 7 安装 python2.7版本
data:image/s3,"s3://crabby-images/5dfc1/5dfc1342d7fe71ce8ff0f5e095fdea22b2189c12" alt=""
我们需要的版本是python 3.6.2,在centos上进行python2和3并存 下载python 3.6.2的包 wget https://www.python.org/ftp/python/3.6.2/Python-3.6.2.tar.xz
data:image/s3,"s3://crabby-images/36ae6/36ae61197fbc8071d44fdd63a59d692991ff836f" alt=""
补充: 协议:网络上数据传输的约定规则 Tcp 面向连接的协议,有校验的数据包 Udp 无连接 可容忍丢包率 http 常规的http https 加密的http ftp 文件传输 Ssh 远程空开 Sftp 基于ssh的文件传输 Smtp 协议
data:image/s3,"s3://crabby-images/ce4bc/ce4bcd7089bdcca119efa843566d568ad1ec59c7" alt=""
解压安装包
data:image/s3,"s3://crabby-images/35ebc/35ebc11fca8eeb765467748b9d7257ef6d1f65d3" alt=""
tar -xvJf Python-3.6.2.tar.xz
data:image/s3,"s3://crabby-images/a0bcd/a0bcdd1cf0ecaa0673df8f9a41490c35a92204d0" alt=""
编译安装
data:image/s3,"s3://crabby-images/c0f3a/c0f3a7f420b5b5f85e038cc9bde89045e3fe7c45" alt=""
./configure prefix=/usr/local/python3
data:image/s3,"s3://crabby-images/0cf50/0cf502cecb92bc8edd2319e56ffe1a761a228ecb" alt=""
data:image/s3,"s3://crabby-images/4a141/4a141e1ebcecbf7c1cd50b867ef709305910e330" alt=""
Make && make install
data:image/s3,"s3://crabby-images/87860/878609d5819476b9dd6f3a3901d48fe016670777" alt=""
data:image/s3,"s3://crabby-images/d67b6/d67b6e460fb2137ce040d5931f5d20af6f19834f" alt=""
配置软连接(环境变量)
data:image/s3,"s3://crabby-images/15df2/15df2f3c8c45d0dd5efd8e44c566849c500a9a58" alt=""
软连接 --> 快捷方式 ln -s /usr/local/python3/bin/python3 /usr/bin/python3 ln -s /usr/local/python3/bin/pip3 /usr/bin/pip3
data:image/s3,"s3://crabby-images/9ab4e/9ab4e3808597bcc3ff33c6b7a0333ed699724304" alt=""
测试:
data:image/s3,"s3://crabby-images/76c4a/76c4aa8afdd183a8671cf60045a485122b5e319f" alt=""
以后我们运行python3的脚本需要编程 python3 *.py 安装python的扩展包 yum install python-devel
data:image/s3,"s3://crabby-images/8333e/8333e27522ae326cd53a6c401d4bff33e84d12f2" alt=""
安装python 开发包 Pymysql Pillow Django2.1.5 django-ckeditor pip3 install pymysql && pip3 install pillow && pip3 install django2.1.5 &&pip3 install django-ckeditor
data:image/s3,"s3://crabby-images/a4831/a4831ee4a251b2b82ccaf95cbb84aeeb93f6a0cd" alt=""
2、Python uwsgi Python 的web项目,本身很难和Apache或者Nginx进行结合,为了让python web项目更加方便的被部署,开发出了uwsgi。 安装: Pip安装uwsgi
data:image/s3,"s3://crabby-images/43728/437283c99e648c2fd8cd752d18c3dbac9fa75582" alt=""
创建软连接 ln -s /usr/local/python3/bin/uwsgi /usr/bin/uwsgi
data:image/s3,"s3://crabby-images/5f957/5f957a06a2e7fa2052e747ac18f383a3c2e3b7c8" alt=""
使用: 我们迁移我们的项目Qshop 复制我们的项目到虚拟机
data:image/s3,"s3://crabby-images/bf8d2/bf8d2b653a93c4880b23fd402886abac3f3d00ea" alt=""
cp -r /root/Desktop/Qshop/ /opt/Qshop
data:image/s3,"s3://crabby-images/ab192/ab19290e325ebe01a4df5c9d6b6ab4fc14efee66" alt=""
我们需要清除pycharm的配置文件,初始的导入文件
data:image/s3,"s3://crabby-images/db1c9/db1c984e4d2f26acc9eaeea489c4234a2b38d089" alt=""
测试项目 python3 manage.py runserver 0.0.0.0:8000
data:image/s3,"s3://crabby-images/7c747/7c747393368b44005f914a5539c13b3b62becc70" alt=""
注意: Systemctl stop firewalld 关闭防火墙
data:image/s3,"s3://crabby-images/85d37/85d3705c06f2b5d4f161e4929a35116e66c9c8b9" alt=""
用uwsgi启动django uwsgi --http 10.10.16.229:8000 --file Qshop/wsgi.py --static-map=/static=static uwsgi 模块名称 –http 协议 10.10.16.229:8000 主机端口 –file uwsgi要使用的解析文件,一般django自己创建 –static 静态目录
data:image/s3,"s3://crabby-images/d3150/d3150fc81b62e9d8f226b5393023dd3dc26a1b91" alt=""
上面我们采用的是命令的方式使用uwsgi启动django,但是,不够完美。我们可以构造配置文件进行操作。 配置内容如下 [uwsgi]
chdir=/opt/OurBlog #项目目录
module=OurBlog.wsgi:application #指定项目的application
socket=/opt/script/uwsgi.sock #指定sock的文件路径
workers=5 #进程个数
pidfile=/opt/script/uwsgi.pid
http= 192.168.2.69:8000 #指定IP端口
static-map=/static=/opt/OurBlog/static #指定静态文件
uid=root #用户
gid=root #组
master=true #启用主进程
vacuum=true #自动移除unix Socket和pid文件当服务停止的时候
enable-threads=true #启用线程
thunder-lock=true #序列化接受的内容,如果可能的话
harakiri=30 #设置自中断时间
post-buffering=4096 #设置缓冲
daemonize=/opt/script/uwsgi.log #设置日志目录
1、创建uwsgi文件的配置文件目录和文件
data:image/s3,"s3://crabby-images/d7f98/d7f98b02c61c4a0df29e23355c41186519e574ca" alt=""
2、编写内容
data:image/s3,"s3://crabby-images/c39b4/c39b48e1afc72f476d558a78b1722efb4bfb27d2" alt=""
启动uwsgi
data:image/s3,"s3://crabby-images/f71b6/f71b69b186c47a9a3955a6b3bab77b3b48cd4ac5" alt=""
授权
data:image/s3,"s3://crabby-images/7c209/7c209aeb64e35597046a2a314016d1ddeaa2f8b2" alt=""
杀死进程重启
data:image/s3,"s3://crabby-images/b1ac2/b1ac2dd2911bbfe3b24b7efab5f90e280646c11a" alt=""
2、Python uwsgi+nginx部署 wget -c https://nginx.org/download/nginx-1.12.2.tar.gz
data:image/s3,"s3://crabby-images/eeb67/eeb67ada2c7694b724b7630b7fc189a3f29fcb75" alt=""
解压 tar -zxvf nginx-1.12.2.tar.gz
data:image/s3,"s3://crabby-images/6dcb2/6dcb2f3c993027bd3b644bedd1c559bece18f97d" alt=""
编译安装 ./configure make && make install
data:image/s3,"s3://crabby-images/aab29/aab29865cce610522bd135fb76050b02ee570f74" alt=""
data:image/s3,"s3://crabby-images/e76d9/e76d936086786d6aa10f5a43b079aa0d5cbbf8b2" alt=""
Nginx /usr/local/nginx
data:image/s3,"s3://crabby-images/99f13/99f1328bec27697a94b02ebd3b84d10de956ef84" alt=""
创建软连接
data:image/s3,"s3://crabby-images/49b26/49b267df081ad13902aa0e6da2bb4732ca6303e0" alt=""
data:image/s3,"s3://crabby-images/3853d/3853d1abfa57937bcf6a7e05c5663f4b36148f55" alt=""
Nginx通讯uwsgi
data:image/s3,"s3://crabby-images/8c40d/8c40d8d4011469ee648707adc884c54bfb142e5d" alt=""
修改Nginx的配置文件
data:image/s3,"s3://crabby-images/ded8d/ded8d8beb03ba0b3d96f0c0ad83fe71cae1fae15" alt=""
备份配置文件
data:image/s3,"s3://crabby-images/4934e/4934e42278c510338dda7ad352f8e8d514a42c0c" alt=""
开始配置
http {
include mime.types;
default_type application/octet-stream;
log_format main '$remote_addr - $remote_user [$time_local] "$request" '
'$status $body_bytes_sent "$http_referer" '
'"$http_user_agent" "$http_x_forwarded_for"'; 日志的格式
#access_log logs/access.log main;
sendfile on;
#tcp_nopush on;
#keepalive_timeout 0;
keepalive_timeout 65;
#gzip on;
server {
listen 80;
server_name Qshop; 服务的名称
charset utf-8; 编码格式
access_log logs/host.access.log main; 访问日志
gzip_types text/plain application/x-javascript text/css text/javascript application/x-httpd-php application/json text/json image/jpeg image/gif image/png application/octet-stream; 访问内容的类型
error_log /var/log/nginx/error.log error; 错误日志,默认没有,需要手动创建
location / {
include uwsgi_params; 加载uwsgi_params
uwsgi_connect_timeout 30; 连接的超时时间 不要加冒号不要加冒号不要加冒号
uwsgi_pass unix:/opt/script/uwsgi.sock; uwsgi.sock通讯的文件地址
}
location = /static/{
alias /opt/Qshop/static; 静态文件的目录
index index.html index.htm;
}</code></pre></div></div><p>杀死当前状态下的所有Nginx服务
Pkill -9 nginx
从新启动
访问网站:
在这里插入图片描述商城数据库读写分离:
知识点:
1、mysql主从备份介绍
2、Linux下的mysql安装
3、基于mysql的Django读写分离
知识点讲解
1、mysql主从备份介绍
备份:安全。
目的:Django网站数据库读写分离设置。在我们工作当中,发现有的数据表经常查询,有的表 经常写入。同时交给一个数据库,效率不高。
在这里插入图片描述
2、Linux下的mysql安装
2台Centos7 虚拟机
Server 主Ip 10.10.16.229
Client 从Ip 10.10.16.141
关闭防火墙
在这里插入图片描述
测试ping
在这里插入图片描述
3、基于mysql的Django读写分离
在Linux安装mariadb数据库
Mysql本身是开源的,大家用的很开心,但是有一家数据库大户,oracle公司看上了mysql,觉得收购,并且答应mysql我们依然开源。果然,后来收费了。Mysql的团队,不忿,然后从新写了mysql的妹妹:mariadb,mariadb和mysql相识度到99%。并且免费。所以,centos7系统,我们使用mariadb。
Centos7 官方yum源包含mariadb的完整安装,所以我们需要的只是一条安装命令。
yum -y install mariadb mariadb-server 安装mariadb
在这里插入图片描述
在这里插入图片描述
Systemctl start mariadb 启动mariadb
在这里插入图片描述
给root添加密码
在这里插入图片描述
安装telnet,这个工具在mysql主从备份会用到
yum install telnet.x86_64 telnet-server.x86_64
在这里插入图片描述
在这里插入图片描述
为了后面的实验,我们在主mysql创建一个小小的数据库
在这里插入图片描述
在这里插入图片描述
主从配置
查看主数据库
在这里插入图片描述
修改数据库配置
/etc/my.cnf
备份配置文件
在这里插入图片描述
访问配置文件
在这里插入图片描述
配置主服务器的配置文件
/etc/my.cnf
在这里插入图片描述
重启mariadb
systemctl restart mariadb
在这里插入图片描述
进入数据库进行授权
GRANT REPLICATION SLAVE ON . TO “root”@“10.10.16.%” IDENTIFIED BY’admin’
GRANT 授权
REPLICATION 权限
SLAVE 备份
ON 在。。之上
. 所有权限
TO 给,去
“root” 用户
“10.10.16.%”16网段所有ip
IDENTIFIED BY 确认密码
Admin 备份的密码
在工作当中,我们备份的时候,可以允许读操作,不允许写操作,我们需要在备份的时候对数据库进行加锁。
加锁
FLUSH TABLES WITH READ LOCK;
然后备份数据库
导入和导出都是基于数据库外的,操作之前请退出数据库
在这里插入图片描述
数据库数据导出
mysqldump -uroot -p123 --all-databases > /root/db.sql
在这里插入图片描述
解锁
在这里插入图片描述
数据库数据导入
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
本章总结
mysql主从备份介绍
Linux下的mysql安装
基于mysql的Django读写分离