最近安装MYSQL 8的时候遇到一些问题,之前MYSQL 8.011 的shell脚本安装8.026 报错,后面手动安装MYSQL虽然没有什么问题,但重复性的劳动也没有人愿意去经常做,所以做了一个简易的python脚本来快速安装8.026。
之前一直想学python,但一直没有时间,所以python的水平一直处于初学的状态。需要将脚本和和 mysql 8.026的bin包放到/root目录下
(代码可能在拷贝后需要进行python缩进调整)
此脚本仅仅为测试环境中使用,环境PYTHON3
#!/usr/bin/python3
import os
import sys
def main():
print('操作会删除MYSQL以及data目录下的数据,如终止操作请按1如继续操作请按0')
temp = input('输入选择数字 0停止 或 1继续')
num = int(temp)
if num == 1:
ip = 'www.baidu.com' #判断是否可以连接internet,能可以继续工作,否退出安装
backinfo = os.system('ping -c 1 -w 1 %s' % ip)
if backinfo:
print('you can not access internet')
else:
print(backinfo)
os.system('yum -y install openssl*')
user = os.system('useradd mysql ')
if user:
print('no_create_user')
else:
print('yes_create_user')
print('请确认要删除 /data /usr/local/mysql 目录 ')
os.system('systemctl stop firewalld')
print('关闭防火墙')
os.system('systemctl disable firewalld')
os.system('setenforce 0')
os.system('getenforce')
print('关闭selinux')
os.system('rm -rf /data')
os.system('rm -rf /usr/local/mysql')
os.system('rm -rf /root/mysql')
os.system('tar xvf /root/mysql-8.0.26-linux-glibc2.12-x86_64.tar.xz')
os.system('mv /root/mysql-8.0.26-linux-glibc2.12-x86_64 /root/mysql')
os.system('mv /root/mysql /usr/local/mysql')
os.system('chown -R mysql:mysql /usr/local/mysql')
os.system('mkdir /data')
os.system('chown -R mysql:mysql /data')
os.system('cp /root/my.cnf /etc/my.cnf')
os.system('/usr/local/mysql/bin/mysqld --initialize-insecure --user=mysql --datadir=/data')
os.system('cp /usr/local/mysql/support-files/mysql.server /etc/init.d/mysqld')
mysql = os.system('service mysqld start')
print (mysql)
else:
print ('停止')
if __name__ == "__main__":
main()
脚本在运行时,需要将mysql 8.026的BIN包和自己写的my.cnf 文件和python脚本放置在root目录。然后直接运行 install_mysql_n.py 即可。此方式安装后的MYSQL root 没有密码。数据目录直接设置在/data下。
后面有时间,可以写一个PG的 自动化安装的脚本。
PostgreSQL 编译安装虽然不是很复杂,对于初学者却是一个小门槛,下面通过python程序快速的安装postgresql 12.6 环境。
请将postgresql 12.6的安装包和install_postgres.py 放置到/root目录中,并赋予执行权限,安装后/pgdata 为主目录, /usr/local/postgres 为主程序的安装路径。另安装过程中请注意联通internet。
#!/usr/bin/python3
import os
import sys
def main():
print('请确认要删除pgdata,如终止操作请按1如继续操作请按0')
temp = input('输入选择数字 0停止 或 1继续')
num = int(temp)
if num == 1:
ip = 'www.baidu.com' #判断是否可以连接internet,能可以继续工作,否退出安装
backinfo = os.system('ping -c 1 -w 1 %s' % ip)
if backinfo:
print('you can not access internet')
else:
print(backinfo)
os.system('userdel postgres')
user = os.system('useradd postgres ')
if user:
print('no_create_user')
else:
print('yes_create_user')
print('请确认要删除 /pgdata /usr/local/postgres 目录 ')
os.system('systemctl stop firewalld')
print('关闭防火墙')
os.system('systemctl disable firewalld')
os.system('setenforce 0')
os.system('getenforce')
print('关闭selinux')
os.system('rm -rf /pgdata')
os.system('rm -rf /usr/local/postgres')
os.system('rm -rf /root/postgres')
os.system('tar xvf /root/postgresql-12.6.tar.gz')
os.system('mv /root/postgresql-12.6 /root/postgres')
os.system('yum -y install bison readline pam')
os.system('yum -y install libxml2 libxml2-devel openssl openssl-devel')
os.system('yum -y install readline-devel zlib zlib-devel')
os.system('yum -y install gcc glibc glibc-common gd gd-devel -y')
os.system('yum -y install libxslt libxslt-devel')
os.system('yum -y install e2fsprogs-devel uuid-devel libuuid-deve libssl* systemd*')
os.system('cd /root/postgres; ./configure --prefix=/usr/local/postgres --bindir=/usr/local/postgres/bin --sysconfdir=/etc --libdir=/usr/local/postgres/libs --includedir=/usr/local/postgres/includes --datadir=/pgdata --datarootdir=/pgdata/root --with-pgport=5432 --with-openssl --with-systemd --with-libxml --with-segsize=4 --with-ossp-uuid')
os.system('cd /root/postgres; gmake')
os.system('cd /root/postgres; gmake install')
os.system('chown -R postgres:postgres /pgdata/ ')
os.system('su - postgres -c "/usr/local/postgres/bin/initdb -D /pgdata/data --wal-segsize=64"')
result = os.system('su - postgres -c "/usr/local/postgres/bin/pg_ctl -D /pgdata/data start"')
print(result)
else:
print ('停止')
if __name__ == "__main__":
main()
以上仅仅在测试环境中部署,不建议在生产环境中操作。
直接在root 目录下执行 ./install_postgres.py 即可, 需要python3环境执行。
服务器托管,北京服务器托管,服务器租用 http://www.fwqtg.net
机房租用,北京机房租用,IDC机房托管, http://www.fwqtg.net
相关推荐: 2023-06-15:说一说Redis的Key和Value的数据结构组织?
2023-06-15:说一说Redis的Key和Value的数据结构组织? 答案2023-06-15: 全局哈希表 Redis使用哈希表作为保存键值对的数据结构,通过哈希函数将Key映射为哈希表中的一个索引位置,使得Key-Value可以在O(1)时间复杂度内…