执行虚拟机mysql脚本_mysql一键执行脚本 超方便!!!

mysql一键执行脚本

mysql一键执行脚本

在初始虚拟机上,直接复制就ok了

#!/bin/bash

echo "-------编译安装mysqld 服务--------"

#将安装mysql 所需软件包传到/opt目录下

#mysql-5.7.17.tar.gz

#boost_1_59_0.tar.gz#支持c++的运行库

echo "安装环境依赖包"

yum -y install gcc gcc-c++ ncurses ncurses-devel bison cmake

echo "配置软件模块"

tar zxvf mysql-5.7.17.tar.gz

tar zxvf boost_1_59_0.tar.gz

cd /opt

mv boost_1_59_0 /usr/local/boost

cd /opt/mysql-5.7.17/

cmake \

-DCMAKE_INSTALL_PREFIX=/usr/local/mysql \

-DMYSQL_UNIX_ADDR=/usr/local/mysql/mysql.sock \

-DSYSCONFDIR=/etc \

-DSYSTEMD_PID_DIR=/usr/local/mysql \

-DDEFAULT_CHARSET=utf8 \

-DDEFAULT_COLLATION=utf8_general_ci \

-DWITH_EXTRA_CHARSETS=all \

-DWITH_INNOBASE_STORAGE_ENGINE=1 \

-DWITH_ARCHIVE_STORAGE_ENGINE=1 \

-DWITH_BLACKHOLE_STORAGE_ENGINE=1 \

-DWITH_PERFSCHEMA_STORAGE_ENGINE=1 \

-DMYSQL_DATADIR=/usr/local/mysql/data \

-DWITH_BOOST=/usr/local/boost \

-DWITH_SYSTEMD=1

echo "编译及安装"

make -j 4 && make install

echo "创建mysql用户"

useradd -M -s /sbin/nologin mysql

echo "修改mysql 配置文件"

[client]

port = 3306

socket=/usr/local/mysql/mysql.sock

echo "[mysqld]

user = mysql

basedir=/usr/local/mysql

datadir=/usr/local/mysql/data

port = 3306

character-set-server=utf8

pid-file = /usr/local/mysql/mysqld.pid

socket=/usr/local/mysql/mysql.sock

bind-address = 0.0.0.0

skip-name-resolve

max_connections=2048

default-storage-engine=INNODB

max_allowed_packet=16M

server-id = 1

sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES,NO_AUTO_CREATE_USER,NO_AUTO_VALUE_ON_ZERO,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,PIPES_AS_CONCAT,ANSI_QUOTES "> /etc/my.cnf echo "更改mysql安装目录和配置文件的属主属组"

chown -R mysql:mysql /usr/local/mysql/

chown mysql:mysql /etc/my.cnf

echo "设置路径环境变量"

echo 'export PATH=/usr/local/mysql/bin:/usr/local/mysql/lib:$PATH' >> /etc/profile

source /etc/profile

echo "初始化数据库"

cd /usr/local/mysql/bin/

./mysqld \

--initialize-insecure \

--user=mysql \

--basedir=/usr/local/mysql \

--datadir=/usr/local/mysql/data

echo "添加mysqld系统服务"

cp /usr/local/mysql/usr/lib/systemd/system/mysqld.service /usr/lib/systemd/system/#用于systemctl服务管理

systemctl daemon-reload

systemctl start mysqld.service

systemctl enable mysqld

netstat -anpt | grep 3306

#修改密码

function abc {

passwd=$1

/usr/bin/expect <

spawn mysqladmin -u root -p password $passwd

expect "Enter password:"

send "\r"

expect eof

EOF

}

abc "abc123"

function bcd {

/usr/bin/expect <

spawn mysql -u root -p

expect "Enter password:" {send "abc123\r"}

expect "mysql>" {send "grant all privileges on *.* to 'root'@'%' identified by 'abc123';\r"}

expect "mysql>" {send "show databases;\r"}

expect "mysql>" {send "quit\r"}

expect eof

EOF

}

bcd

echo "安装完成"1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

65

66

67

68

69

70

71

72

73

74

75

76

77

78

79

80

81

82

83

84

85

86

87

88

89

90

91

92

93

94

95

96

97

98

99

100

101

102

103

104

105

106

107

108

109

110

111

112

113

114

115

116

117

118

文章来源: blog.csdn.net,作者:朝花夕誓丶,版权归原作者所有,如需转载,请联系作者。

原文链接:blog.csdn.net/weixin_51614581/article/details/113183796

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值