暂无图片
暂无图片
暂无图片
暂无图片
暂无图片

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

AustinDatabases 2021-11-04
668

最近安装MYSQL 8的时候遇到一些问题,之前MYSQL 8.011 的shell脚本安装8.026 报错,后面手动安装MYSQL虽然没有什么问题,但重复性的劳动也没有人愿意去经常做,所以做了一个简易的python脚本来快速安装8.026。

之前一直想学python,但一直没有时间,所以python的水平一直处于初学的状态。需要将脚本和和 mysql 8.026的bin包放到/root目录下

(代码可能在拷贝后需要进行python缩进调整)

此脚本仅仅为测试环境中使用,环境PYTHON3

#!/usr/bin/python3import osimport sysdef 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/python3import osimport sysdef 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环境执行。





文章转载自AustinDatabases,如果涉嫌侵权,请发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

评论