Linux(三)—— 项目部署环境搭建

时间:2024-05-04 13:05:55

项目部署环境搭建

[TOC]

一、linux上网

安装好linux系统后,就配置好了

二、rpm包管理

1、光盘挂载

 mount /dev/cdrom /mnt     # 挂载
cd /mnt # 进入mnt目录
ls # 查看

2、安装卸载rpm包

  • 进入Packages中才能安装软件
 rpm -ivh vsftpd-3.0.2-22.el7.x86_64.rpm(包名-版本号.平台)     # 安装
rpm -Uvh vsftpd-3.0.2-22.el7.x86_64.rpm # 有就更新,没有就安装
 rpm -e vsftpd-3.0.2-22.el7.x86_64    # 卸载

3、查询是否安装

rpm -q vsftpd(软件包名)     # 查询
rpm -qa |grep vsf # 模糊查询

4、查看软件包

which vim     # 查看命令的具体路径  /usr/bin/vim
rpm -qf /usr/bin/vim # 查看命令来自哪个软件包

5、互相依赖关系的软件包

rpm -ivh a b c d e    # 所有软件包一起安装

三、yum包管理

1、使用aliyun的yum源

# 1.安装BASE源
cd /etc/yum.repos.d/ # 切换到源的配置文件
mv *.repo /tmp # 将系统自带的源清除
wget http://mirrors.aliyun.com/repo/Centos-7.repo # 下载安装centos # 2.安装EPEL源
yum install -y epel-release

2、使用yum安装软件

[root@python3 ~]# yum install openssl
yum install openssl-devel

3、查看yum源的软件包

yum list
yum list |grep vsftpd() # 查看vsftpd开头的所有软件包
yum grouplist # 查看所有的组
yum groupinstall "Developement Tools" # 安装一个组的软件包

4、删除软件包

 yum remove aaaa(软件包名)

5、优化yum源

(1)使用本地源

# 1.将原来的包移除
mv *.repo ali
# 2.创建源
vim local.repo
# 3.编辑,内容如下:
[local]
name=localios
baseurl=file:///mnt
gpgchech=0
# 4.清空原来的源
yum clean all
# 5.下载
yum install -y vsftpd

(2)局域网yum源配置

# 1.安装ftp软件
yum install -y vsftpd # 2.启动ftp服务
[root@python3 ~]# systemctl start vsftpd
[root@python3 ~]# systemctl enable vsftpd # 3.创建站点目录,并将光盘软件拷贝到其中
mkdir /var/ftp/pub/centos7
[root@python3 ~]# cp -a /mnt/* /var/ftp/pub/centos7 # 4.生成ftp站点的yum源配置文件
vim ftp.repo # 创建并进入编辑
# 编辑内容如下:
[ftp]
name=centos7
baseurl=ftp://10.0.0.100/pub/centos7
gpgcheck=0 # 5.安装测试软件
yum install openssl-devel bzip2-devel expat-devel gdbm-devel readline-devel sqlite-devel gcc gcc-c++ openssl-devel zlib zlib-devel -y

四、源码包应用

0、源码包解压缩

# .zip文件解压缩
unzip xxx.zip # .tar / .tar.gz / .tgz / .tar.bz2 / .tar.xz解压
tar xf xxx.tar # .iso使用
mount -o loop xxx.iso /test # .iso文件使用,必须要先挂载到某处再使用 # .cpio(早起文件的打包方式)
cpio -idcmv < xxx.cpio

1、python3.6安装

# 1.现将源码文件压缩包拖入在opt目录中
cd /opt # 进入opt目录
ls # 查看opt目录下所有的文件,显示为红色的压缩包 # 2.python使用c编译,现状gcc环境
[root@py3 opt]# yum install gcc* # 安装所有gcc包 # 3.安装openssl,支持访问http站点
[root@py3 opt]# yum install -y openssl # 4.解压
[root@py3 opt]# tar xf Python-3.6.1.tar.xz # 5.进入目录,配置
[root@py3 opt]# cd Python-3.6.1/
[root@py3 Python-3.6.1]# ./confugure # 定制功能,检查是否满足软件包的安装 # 6.编译c源码生成二进制
make # 7.完善编译,完成拷贝授权
make install

2、mysql源码包安装

cmake    # 定制功能
make # 编译
make install # 授权拷贝

3、redis源码包安装

# 1.现将源码文件压缩包拖入在opt目录中
cd /opt # 进入opt目录
ls # 查看opt目录下所有的文件,显示为红色的压缩包 # 2.解压
[root@py3 opt]# tar xf redis-3.2.10.tar.gz # 3.进入目录
[root@py3 opt]# cd redis-3.2.10/ # 4.编译c源码生成二进制
[root@py3 redis-3.2.10]# make # 5.设置环境变量
vim /etc/profile
# 在文件最后一行加上
export PATH=/opt/redis-3.2.10/src:$PATH # 6、生效
source /etc/profile # 7.启动
[root@py3 ~]# redis-server & # 8.python连接redis
[root@py3 opt]# unzip redis-py-master.zip # 解压驱动包
cd redis-py-master # 进入驱动目录
[root@py3 redis-py-master]# python3 setup.py install # 手动安装python包 # 9.测试python连接redis
python3
>>>import redis
>>>r = redis.StrictRedis(host='localhost', port=6379)
>>>r.set('name', 'oldguo')
True
>>>r.get('name')
'oldguo'

五、二进制包使用(mysql安装)

例如:mysql5.7.20二进制包安装

useradd mysql
mkdir /opt/mysql/data
chown -R mysql.mysql /opt/mysql# 1.现将源码文件压缩包拖入在opt目录中
cd /opt # 进入opt目录,手动拖入
ls # 查看opt目录下所有的文件,显示为红色的压缩包 # 可以设置一个软链接(快捷方式)
[root@py3 opt]# ln -s mysql-5.7.20-linux-glibc2.12-x86_64 mysql # 2.设置环境变量
vim /etc/profile
# 编辑环境变量,添加内容如下:
export PATH=/opt/mysql/bin:$PATH # 3.生效配置
source /etc/profile # 4.卸载自带的mariadb
yum remove mariadb-libs # 5.生成配置文件
vim /etc/my.cnf # 进入配置文件
#内容如下:
[mysqld]
basedir=/opt/mysql
datadir=/opt/mysql/data
socket=/tmp/mysql.sock
user=mysql
log_error=/var/log/mysql.log
log_bin=/opt/mysql/data/mysql-bin
server_id=100
[mysql]
socket=/tmp/mysql.sock # 6.创建用户和数据目录,并授权
[root@py3 ~]# useradd mysql # 创建用户
[root@py3 ~]# mkdir /opt/mysql/data # 创建目录
[root@py3 ~]# chown -R mysql.mysql /opt/mysql # 授权 # 7.初始化数据
[root@py3 ~]# touch /var/log/mysql.log # 创建空文件
[root@py3 ~]# chown -R mysql.mysql /var/log/mysql.log # 授权
[root@py3 ~]# mysqld --initialize-insecure --basedir=/opt/mysql --datadir=/opt/mysql/data --user=mysql # 初始化 # 8.启动mysql数据库
cd /opt/mysql/support-files
[root@py3 support-files]# ./mysql.server start
[root@py3 support-files]# cp mysql.server /etc/init.d/mysqld # 方便以后启动 # 拷贝完以后,启动mysql
/etc/init.d/mysqld restart # 或者使用systemctl启动
# 生成配置文件
vim /etc/systemd/system/mysqld.service
# 编辑内容如下:
[Unit]
Description=MySQL Server
Documentation=man:mysqld(8)
Documentation=http://dev.mysql.com/doc/refman/en/using-systemd.html
After=network.target
After=syslog.target [Install]
WantedBy=multi-user.target
[Service]
User=mysql
Group=mysql
ExecStart=/opt/mysql/bin/mysqld --defaults-file=/etc/my.cnf
LimitNOFILE = 5000
# 启动关闭
[root@py3 support-files]# systemctl start mysqld
[root@py3 support-files]# systemctl restart mysqld
[root@py3 support-files]# systemctl stop mysqld
# 注意不能两种启动凡是混合使用 # 9.测试mysql
[root@py3 ~]# mysql # 10.python连接mysql测试
mysql>grand all on *.* root@'10.0.0.100' idenitfied by '123'; # 授权用户
mysql>create database bbs charset utf8; # 创建数据库 # 安装python连接mysql的包
[root@py3 ~]# pip3 install --upgrade pip # 更新pip
[root@py3 ~]# pip3 install pymysql # 安装pymysql
# 测试python程序
vim test.py
# 测试内容
import pymysql
db = pymysql.connect("10.0.0.100","root","123","bbs" )
cursor.execute("SELECT VERSION()")
data = cursor.fetchone()
print ("Database version : %s " % data)
db.close()
# 执行python文件
[root@py3 ~]# python3 test.py

六、运行Django项目

1、安装依赖包

[root@web01 ~]# yum install openssl-devel bzip2-devel expat-devel gdbm-devel readline-devel sqlite-devel gcc gcc-c++  openssl-devel zlib zlib-devel -y

2、安装测试Django框架和uwsgi

(1)安装Django框架和uwsgi

# 方式一:从官网下
pip3 install uwsgi
pip3 install django
pip3 install other
pip3 install bs4 # 方式二:从国内下
vim re.txt
# 内容:
asn1crypto==0.24.0
beautifulsoup4==4.6.3
bs4==0.0.1
certifi==2018.4.16
cffi==1.11.5
chardet==3.0.4
Click==7.0
cryptography==2.3.1
Django==1.11.9
Flask==1.0.2
Flask-Cors==3.0.6
gevent==1.3.6
greenlet==0.4.15
idna==2.7
ItsDangerous==1.1.0
Jinja2==2.10
lxml==4.2.6
MarkupSafe==1.0
numpy==1.15.3
Pillow==5.3.0
pycparser==2.18
PyMySQL==0.9.2
pytz==2018.7
requests==2.19.1
selenium==3.141.0
six==1.11.0
urllib3==1.23
virtualenv==16.1.0
Werkzeug==0.14.1
wordcloud==1.5.0
# 从豆瓣上下载Django和uwsgi等包
pip3 install -i https://pypi.doubanio.com/simple/ -r re.txt

(2)测试uwsgi

# 测试uwsgi
# 普通用户测试 [root@py3 ~]# useradd test
[root@py3 ~]# cd /opt
[root@py3 opt]# vim test.py
[root@py3 ~]# su - test # 切换用户,用普通启动uwsgi
[test@py3 ~]# cd /opt
# 内容:
def application(env, start_response):
start_response('200 OK', [('Content-Type','text/html')])
return [b"Hello Django"]
[test@py3 opt]# uwsgi --http :8001 --wsgi-file test.py & # 运行test文件 # 启动uwsgi以后,运行test.py,浏览器访问10.0.0.100:8001,成功则访问到Hello Django

(3)测试Django项目

# 测试Django
[root@web01 ~]# django-admin.py startproject demosite # 生成一个空的Django项目
[root@web01 ~]# cd demosite # 进入demosite项目
[root@web01 demosite]# python3 manage.py runserver 0.0.0.0:8002 # 启动Django项目 # 将项目中的setting.py文件中的 ALLOWED_HOSTS=[]修改为ALLOWED_HOSTS=['*'],使所有地址都可以访问
# 在浏览器中,测试是否运行成功,10.0.0.100:8002 ,成功则访问到空Django页面

3、配置uwsgi与nginx

  • uwsgi

    Django 所提供的是一个开发服务器,这个开发服务器,没有经过安全测试,而且使用的是 Python 自带的 simple HTTPServer 创建的,在安全性和效率上都是不行的
    
    而uWSGI 是一个全功能的 HTTP 服务器,他要做的就是把 HTTP 协议转化成语言支持的网络协议。比如把 HTTP 协议转化成 WSGI 协议,让 Python 可以直接使用
    
    
  • nginx
    Nginx是一个轻量级、高性能、稳定性高、并发性好的HTTP和反向代理服务器

    正向代理:某些情况下,代理我们用户去访问服务器,需要用户手动的设置代理服务器的ip和端口号。
    反向代理:是用来代理服务器的,代理我们要访问的目标服务器。
    代理服务器接受请求,然后将请求转发给内部网络的服务器(集群化),
    并将从服务器上得到的结果返回给客户端,此时代理服务器对外就表现为一个服务器

(1)配置uwsgi

# 1.配置
[root@web01 demosite]# vim /root/demosite/uwsgi.ini # 编辑uwsgi的配置文件
# 内容如下:
[uwsgi]
socket = 127.0.0.1:9999
master = true
workers = 2
max-requests = 1000
buffer-size = 30000
pidfile = /run/uwsgi.pid
daemonize = /var/log/uwsgi.log # 2.启动uwsgi
[root@web01 demosite]# uwsgi --ini /root/demosite/uwsgi.ini &

(2)配置nginx

# 1.配置nginx
[root@web01 demosite]# vim /etc/nginx/conf.d/py.conf
# 编辑内容:
server {
listen 80;
server_name 10.0.0.100;
client_max_body_size 100M; location / {
index index.html;
include uwsgi_params;
uwsgi_pass 127.0.0.1:9999;
uwsgi_param UWSGI_SCRIPT demosite.wsgi; # demosite.wsgi 是
uwsgi_param UWSGI_CHDIR /root/demosite; # /root/demosite 是项目目录
}
} # 2.重启nginx
[root@web01 demosite]# systemctl restart nginx

(3)测试

浏览器访问10.0.0.100,不用输端口号,就可以访问Django的项目的页面