python安装lnmp

#!/usr/bin/python
# -*- coding:utf-8 -*-
# 注意:本实验用root用户。已经安装python3.6.5  用pycharm运行,首先把nginx安装包放在 /usr/local 下面;mysql安装包放在/root/soft/下面;php7.11安装包不用提前准备,网络下载就行
import subprocess
import sys
import os

info = '''    #定义开头显示的提示选择信息
    ----- Select Install option -----
    1.Install Nginx-1.12.2
    2.Install mysql-5.7.22
    3.Install PHP-7.1.1

    5.Exit Program
    ---------------------------------
    '''
nginx_service = '''
[Unit]
Description=nginx
After=network.target

[Service]
Type=forking
ExecStart=/usr/local/nginx/sbin/nginx
ExecReload=/usr/local/nginx/sbin/nginx -s reload
ExecStop=/usr/local/nginx/sbin/nginx -s quit
PrivateTmp=true

[Install]
WantedBy=multi-user.target
'''
my_cnf = '''
[mysqld]
basedir=/usr/local/mysql                           #介质目录
datadir=/usr/local/mysql/data                      #数据目录
port=3306                                          #端口
pid-file = /usr/local/mysql/data/mysqld.pid        #进程id
user = mysql                                       #启动用户
socket=/tmp/mysql.sock                             #sock文件地址
bind-address = 0.0.0.0                             #绑定ip 这里表示绑定所有ip
server-id = 1                                      #用于复制环境钟标识实例,这个在复制环境里唯一
character-set-server = utf8                        #服务端默认字符集,很重要,错误设置会出现乱码
max_connections = 1000                             #允许客户端并发连接的最大数量
max_connect_errors = 6000                          #如果客户端尝试连接的错误数量超过这个参数设置的值,则服务器不再接受新的客户端连接
open_files_limit = 65535                           #操作系统允许MySQL服务打开的文件数量。
table_open_cache = 128                             #所有线程能打开的表的数量
max_allowed_packet = 32M                            #网络传输时单个数据包的大小。
binlog_cache_size = 1M
max_heap_table_size = 1288M
tmp_table_size = 16M
read_buffer_size = 2M
read_rnd_buffer_size = 8M
sort_buffer_size = 16M
join_buffer_size = 16M
key_buffer_size = 4M
thread_cache_size = 8
query_cache_type = 1
query_cache_size = 4096M
query_cache_limit = 4M
ft_min_word_len = 4
log_bin = mysql-bin
binlog_format = mixed
expire_logs_days = 30
log_error = /usr/local/mysql/data/mysql-error.log               #错误日志地址
slow_query_log = 1
long_query_time = 1
slow_query_log_file = /usr/local/mysql/data/mysql-slow.log      #慢查询日志
performance_schema = 0
explicit_defaults_for_timestamp
lower_case_table_names = 1
skip-external-locking
default_storage_engine = InnoDB
#default-storage-engine = MyISAM
innodb_file_per_table = 1
innodb_open_files = 16350
innodb_buffer_pool_size = 10G
innodb_write_io_threads = 16
innodb_read_io_threads = 16
innodb_thread_concurrency = 32
innodb_purge_threads = 1
innodb_flush_log_at_trx_commit = 2
innodb_log_buffer_size = 128M
innodb_log_file_size = 1G
innodb_log_files_in_group = 3
innodb_max_dirty_pages_pct = 90
innodb_lock_wait_timeout = 120
bulk_insert_buffer_size = 8M
myisam_sort_buffer_size = 8M
myisam_max_sort_file_size = 10G
myisam_repair_threads = 1
interactive_timeout = 512
wait_timeout = 256
#lower_case_table_names = 1
skip-external-locking
default_storage_engine = InnoDB
#default-storage-engine = MyISAM
sql_mode='NO_AUTO_VALUE_ON_ZERO,STRICT_TRANS_TABLES,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION,PIPES_AS_CONCAT,ANSI_QUOTES'

[client]
port=3306
socket=/tmp/mysql.sock
[mysql]
socket=/tmp/mysql.sock

#开启快速度导出
[mysqldump]
quick
default-character-set = utf8mb4
max_allowed_packet = 256M

[myisamchk]

key_buffer_size = 20M
sort_buffer_size = 20M
read_buffer = 2M
write_buffer = 2M


'''

while True:
    print(info)
    n = input('Input your select: ')
    if n.isdigit():  # 判断是否是数字
        n = int(n)  # 如果是就转换成整型,raw_input接收类型默认是字符串型
        if n <= 5 and n >= 1:  # 数字必须在可选范围之内
            if not os.path.isdir('/data'):  # 判断是否存在/data目录
                os.mkdir('/data')  # 不存在就创建
            else:
                if n == 1:  # 如果选的是1,运行shell命令安装nginx
                    print("创建nginx用户")
                    subprocess.call(["useradd nginx"], shell=True)
                    print("安装依赖环境")
                    subprocess.call([
                        "yum install gcc gcc-c++ zlib zlib-devel openssl openssl-devel pcre pcre-devel autoconf automake libtool make -y"],
                            shell=True)
                    print("编译安装")
                    subprocess.call([
                        "cd /usr/local && tar -xf nginx-1.12.2.tar.gz && cd nginx-1.12.2 && ./configure --prefix=/usr/local/nginx --conf-path=/etc/nginx/nginx.conf --with-http_stub_status_module --with-http_ssl_module --with-stream && make && make install"],
                            shell=True)
                    print("设置环境变量")
                    subprocess.call(["echo 'export PATH=$PATH:/usr/local/nginx/sbin' >> /etc/profile"], shell=True)
                    subprocess.call(["source /etc/profile"], shell=True)
                    print("设置配置文件")
                    subprocess.call(["/usr/local/nginx/sbin/nginx -c /usr/local/nginx/conf/nginx.conf"], shell=True)

                    print("创建开机自启文件")
                    with open("/lib/systemd/system/nginx.service", "a") as f:
                        f.write(my_cnf)
                    f.close()
                    print("设置开机启动")
                    subprocess.call(["systemctl enable nginx.service"], shell=True)
                    print("启动nginx服务")
                    subprocess.call(["systemctl start nginx.service"], shell=True)
                    print("重新加载nginx")
                    subprocess.call(["nginx -s reload"], shell=True)

                if n == 2:  # 编译安装mysql,每个命令都在屏幕上显示;安装包提前放在/root/soft目录下
                    print("remove mariadb")
                    subprocess.call(["yum remove maria* -y"], shell=True)
                    print("清空my.cnf")
                    subprocess.call(["echo > /etc/my.cnf"], shell=True)
                    print("useradd mysql")
                    subprocess.call(["useradd mysql && groupadd mysql && useradd -r -g mysql mysql"], shell=True)
                    print("tar -zxvf mysql-5.7.22-linux-glibc2.12-x86_64.tar.gz")
                    subprocess.call(["cd /root/soft/ && tar -zxvf mysql-5.7.22-linux-glibc2.12-x86_64.tar.gz"],
                                    shell=True)
                    print("mv /root/soft/mysql-5.7.22-linux-glibc2.12-x86_64 /usr/local/mysql")
                    subprocess.call(["cd /root/soft/ && mv mysql-5.7.22-linux-glibc2.12-x86_64 /usr/local/mysql"],
                                    shell=True)
                    print("chown -R mysql:mysql /usr/local/mysql")
                    subprocess.call(["chown -R mysql:mysql /usr/local/mysql"], shell=True)
                    print("初始化mysql")
                    subprocess.call([
                        "cd /usr/local/mysql/ && bin/mysqld --initialize --user=mysql --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data"],
                            shell=True)
                    print("创建RSA private key")
                    subprocess.call(["cd /usr/local/mysql && bin/mysql_ssl_rsa_setup --datadir=/usr/local/mysql/data"],
                                    shell=True)
                    subprocess.call(["chown -R mysql:mysql /usr/local/mysql/data"], shell=True)

                    print("创建mysql配置文件")
                    with open("/etc/my.cnf", "a") as f:
                        f.write(my_cnf)
                    f.close()
                    print("添加开机启动")
                    subprocess.call(["cp /usr/local/mysql/support-files/mysql.server /etc/init.d/mysqld"], shell=True)
                    print("修改配置文件")
                    subprocess.call(["sed -i '2a basedir=/usr/local/mysql' /etc/init.d/mysqld "], shell=True)
                    subprocess.call(["sed -i '3a datadir=/usr/local/mysql/data' /etc/init.d/mysqld "], shell=True)
                    print("添加环境变量")
                    subprocess.call([
                        "sed -i '$a\PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/root/bin:/root/bin:/usr/local/mysql/bin' ~/.bash_profile && source ~/.bash_profile"],
                            shell=True)
                    print("启动mysq")
                    subprocess.call(["systemctl daemon-reload && systemctl start mysqld"], shell=True)
                    print("设置mysql的bin目录连接")
                    subprocess.call(["ln -s /usr/local/mysql/bin/mysql /usr/bin"], shell=True)
                    print("设置开机自启")
                    subprocess.call(["chmod +x /etc/init.d/mysqld && chkconfig --add mysqld"], shell=True)

                if n == 3:
                    print("安装依赖包")
                    subprocess.call(
                            [
                                "yum install openldap openldap-devel epel-release gcc gcc-c++ libxml2 libxml2-devel openssl openssl-devel bzip2 bzip2-devel libcurl libcurl-devel libjpeg libjpeg-devel libpng libpng-devel freetype freetype-devel gmp gmp-devel libmcrypt libmcrypt-devel readline readline-devel libxslt libxslt-devel -y"],
                            shell=True)
                    print("下载安装包、编译安装php")
                    subprocess.call(["cd /usr/local && wget -O php7.tar.gz http://cn2.php.net/get/php-7.1.1.tar.gz/from/this/mirror && tar -xvf php7.tar.gz && cd php-7.1.1/ && ./configure \
--prefix=/usr/local/php \
--with-config-file-path=/etc \
--enable-fpm \
--with-fpm-user=nginx \
--with-fpm-group=nginx \
--enable-inline-optimization \
--disable-debug \
--disable-rpath \
--enable-shared \
--enable-soap \
--with-libxml-dir \
--with-xmlrpc \
--with-openssl \
--with-mcrypt \
--with-mhash \
--with-pcre-regex \
--with-sqlite3 \
--with-zlib \
--enable-bcmath \
--with-iconv \
--with-bz2 \
--enable-calendar \
--with-curl \
--with-cdb \
--enable-dom \
--enable-exif \
--enable-fileinfo \
--enable-filter \
--with-pcre-dir \
--enable-ftp \
--with-gd \
--with-openssl-dir \
--with-jpeg-dir \
--with-png-dir \
--with-zlib-dir \
--with-freetype-dir \
--enable-gd-native-ttf \
--enable-gd-jis-conv \
--with-gettext \
--with-gmp \
--with-mhash \
--enable-json \
--enable-mbstring \
--enable-mbregex \
--enable-mbregex-backtrack \
--with-libmbfl \
--with-onig \
--enable-pdo \
--with-mysqli=mysqlnd \
--with-pdo-mysql=mysqlnd \
--with-zlib-dir \
--with-pdo-sqlite \
--with-readline \
--enable-session \
--enable-shmop \
--enable-simplexml \
--enable-sockets \
--enable-sysvmsg \
--enable-sysvsem \
--enable-sysvshm \
--enable-wddx \
--with-libxml-dir \
--with-xsl \
--enable-zip \
--with-ldap \
--enable-mysqlnd-compression-support \
--with-pear \
--enable-opcache && make && make install"], shell=True)
                    print("配置环境变量")
                    subprocess.call(["sed -i '$a\export PATH=$PATH:/usr/local/php/bin' /etc/profile && source /etc/profile"], shell=True)
                    print("配置php-fpm")
                    subprocess.call([
                        "cp /usr/local/php-7.1.1/php.ini-production /etc/php.ini && cp /usr/local/php/etc/php-fpm.conf.default /usr/local/php/etc/php-fpm.conf"],
                            shell=True)
                    subprocess.call([
                        "cp /usr/local/php/etc/php-fpm.d/www.conf.default /usr/local/php/etc/php-fpm.d/www.conf"],
                            shell=True)
                    subprocess.call([
                        "cp /usr/local/php-7.1.1/sapi/fpm/init.d.php-fpm /etc/init.d/php-fpm"],
                            shell=True)
                    print("给php启动脚本授权")
                    subprocess.call(["chmod +x /etc/init.d/php-fpm"], shell=True)
                    print("启动php")
                    subprocess.call(["/etc/init.d/php-fpm start"], shell=True)
                    print("设置开机自启")
                    subprocess.call(["chkconfig --add php-fpm"], shell=True)

                if n == 5:  # 退出程序
                    print("Program will be quite!")
                    sys.exit()
                else:
                    print('you select is not correct')
        else:
            print('you should input number')
 

 

posted @ 2018-11-19 11:10  effortsing  阅读(791)  评论(0编辑  收藏  举报