前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >--MYSQL and PostgreSQL python快速搭建MYSQL 8.026 和 PostgreSQL 12.6

--MYSQL and PostgreSQL python快速搭建MYSQL 8.026 和 PostgreSQL 12.6

作者头像
AustinDatabases
发布2021-11-10 15:24:29
6830
发布2021-11-10 15:24:29
举报
文章被收录于专栏:AustinDatabasesAustinDatabases

最近安装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环境执行。

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2021-11-04,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 AustinDatabases 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档