MariaDB10自动化安装部署

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,高可用系列 2核4GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介:

去MariaDB官网下载MariaDB本文用的是MariaDB 10.1.16

 https://downloads.mariadb.org


选择二进制版本,下载到/root目录下

mariadb-10.1.16-linux-x86_64.tar.gz





开始安装

[root@HE3 ~]# cat mariadb_auto_install.sh

[root@HE3 ~]# cat mariadb_auto_install.sh

[root@HE3 ~]# cat mariadb_auto_install.sh 

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
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
###### 二进制自动安装数据库脚本root密码MANAGER将脚本和安装包放在/root目录即可###############
######数据库目录/usr/local/mysql############
######数据目录/data/mysql############
######日志目录/log/mysql############
######端口号默认3306其余参数按需自行修改############
##################
#author:rrhelei@126.com#
##################
#!/bin/bash
PATH= /bin : /sbin : /usr/bin : /usr/sbin : /opt/bin : /opt/sbin :~ /bin
export  PATH
# Check if user is root
if  [ $( id  -u) !=  "0"  ];  then
     echo  "Error: You must be root to run this script, please use root to install"
     exit  1
fi
clear
echo  "========================================================================="
echo  "A tool to auto-compile & install MariaDB 10.1.16 on Redhat/CentOS Linux "
echo  "========================================================================="
cur_dir=$( pwd )
#set mysql root password
echo  "==========================="
mysqlrootpwd= "MANAGER"
echo  -e  "Please input the root password of mysql:"
read  -p  "(Default password: MANAGER):"  mysqlrootpwd
if  "$mysqlrootpwd"  ""  ];  then
mysqlrootpwd= "MANAGER"
fi
echo  "==========================="
echo  "MySQL root password:$mysqlrootpwd"
echo  "==========================="
#which MySQL Version do you want to install?
echo  "==========================="
isinstallmysql56= "n"
echo  "Install MariaDB 10.1.16,Please input y"
read  -p  "(Please input y , n):"  isinstallmysql56
case  "$isinstallmysql56"  in
y|Y|Yes|YES| yes |yES|yEs|YeS|yeS)
echo  "You will install MySQL 5.6.25"
isinstallmysql56= "y"
;;
*)
echo  "INPUT error,You will exit install MariaDB 10.1.16"
isinstallmysql56= "n"
     exit
esac
get_char()
{
SAVEDSTTY=`stty -g`
stty - echo
stty cbreak
#dd if=/dev/tty bs=1 count=1 2> /dev/null
stty -raw
stty  echo
stty $SAVEDSTTY
}
echo  ""
echo  "Press any key to start...or Press Ctrl+c to cancel"
char=`get_char`
# Initialize  the installation related content.
function  InitInstall()
{
cat  /etc/issue
uname  -a
MemTotal=` free  -m |  grep  Mem |  awk  '{print  $2}' `  
echo  -e  "\n Memory is: ${MemTotal} MB "
#Set timezone
rm  -rf  /etc/localtime
ln  -s  /usr/share/zoneinfo/Asia/Shanghai  /etc/localtime
     #Delete Old Mysql program
rpm -qa| grep  mysql
rpm -e mysql
#Disable SeLinux
if  [ -s  /etc/selinux/config  ];  then
sed  -i  's/SELINUX=enforcing/SELINUX=disabled/g'  /etc/selinux/config
fi
     setenforce 0
}
#Installation of depend on and optimization options.
function  InstallDependsAndOpt()
{
cd  $cur_dir
cat  >> /etc/security/limits .conf<<EOF
* soft nproc 65535
* hard nproc 65535
* soft nofile 65535
* hard nofile 65535
EOF
echo  "fs.file-max=65535"  >>  /etc/sysctl .conf
}
#Install MySQL
function  InstallMySQL56()
{
echo  "============================Install MariaDB 10.1.16=================================="
cd  $cur_dir
#Backup old my.cnf
#rm -f /etc/my.cnf
if  [ -s  /etc/my .cnf ];  then
     mv  /etc/my .cnf  /etc/my .cnf.` date  +%Y%m%d%H%M%S`.bak
fi
#mysql directory configuration
groupadd mysql -g 512
useradd  -u 512 -g mysql -s  /sbin/nologin  -d  /home/mysql  mysql
tar  xvf  /root/mariadb-10 .1.16-linux-x86_64. tar .gz
mv  /root/mariadb-10 .1.16-linux-x86_64  /usr/local/mysql
mkdir  -p  /data/mysql
mkdir  -p  /log/mysql
chown  -R mysql:mysql  /data/mysql
chown  -R mysql:mysql  /usr/local/mysql
chown  -R mysql:mysql  /log
SERVERID=` ifconfig  eth0 |  grep  "inet addr"  awk  '{ print $2}' awk  -F.  '{ print $3$4}' `
cat  >> /etc/my .cnf<<EOF
[client]
port= 3306
socket=  /tmp/mysql .sock
default-character- set =utf8
[mysql]
default-character- set =utf8
[mysqld]
port= 3306
socket=  /tmp/mysql .sock
basedir=  /usr/local/mysql
datadir=  /data/mysql
open_files_limit    = 3072
back_log = 103
max_connections = 800
max_connect_errors = 100000
table_open_cache = 512
external-locking = FALSE
max_allowed_packet = 32M
sort_buffer_size = 2M
join_buffer_size = 2M
thread_cache_size = 51
query_cache_size = 32M
tmp_table_size = 96M
max_heap_table_size = 96M
slow_query_log = 1
slow_query_log_file =  /log/mysql/slow .log
log-error =  /log/mysql/error .log
long_query_time = 1
server- id  = $SERVERID
log-bin =  /log/mysql/mysql-bin
sync_binlog = 1
binlog_cache_size = 4M
max_binlog_cache_size = 8M
max_binlog_size = 1024M
expire_logs_days = 60
key_buffer_size = 32M
read_buffer_size = 1M
read_rnd_buffer_size = 16M
bulk_insert_buffer_size = 64M
character- set -server=utf8
default-storage-engine = InnoDB
binlog_format = row
innodb_buffer_pool_dump_at_shutdown = 1
innodb_buffer_pool_load_at_startup = 1
binlog_rows_query_log_events = 1
explicit_defaults_for_timestamp = 1
#log_slave_updates=1
#gtid_mode=on
#enforce_gtid_consistency=1
#innodb_write_io_threads = 8
#innodb_read_io_threads = 8
#innodb_thread_concurrency = 0
transaction_isolation = REPEATABLE-READ
innodb_additional_mem_pool_size = 16M
innodb_buffer_pool_size = 512M
#innodb_data_home_dir =
innodb_data_file_path = ibdata1:1024M:autoextend
innodb_flush_log_at_trx_commit = 1
innodb_log_buffer_size = 16M
innodb_log_file_size = 512M
innodb_log_files_in_group = 2
innodb_max_dirty_pages_pct = 50
innodb_file_per_table = 1
innodb_locks_unsafe_for_binlog = 0
wait_timeout = 14400
interactive_timeout = 14400
skip-name-resolve
[mysqldump]
quick
max_allowed_packet = 32M
EOF
/usr/local/mysql/scripts/mysql_install_db  --basedir= /usr/local/mysql  --datadir= /data/mysql  --defaults- file = /etc/my .cnf --user=mysql
cp  /usr/local/mysql/support-files/mysql .server  /etc/init .d /mysqld
chmod  700  /etc/init .d /mysqld
chkconfig --add mysql
chkconfig --level 2345 mysqld on
cat  >>  /etc/ld .so.conf.d /mysql-x86_64 .conf<<EOF
/usr/local/mysql/lib
EOF
ldconfig
if  [ -d  "/proc/vz"  ]; then
ulimit  -s unlimited
fi
/etc/init .d /mysqld  start
cat  >>  /etc/profile  <<EOF
export  PATH=$PATH: /usr/local/mysql/bin
export  LD_LIBRARY_PATH= /usr/local/mysql/lib
EOF
/usr/local/mysql/bin/mysqladmin  -u root password $mysqlrootpwd
cat  /tmp/mysql_sec_script <<EOF
use mysql;
delete from mysql.user where user!= 'root'  or host!= 'localhost' ;
flush privileges;
EOF
/usr/local/mysql/bin/mysql  -u root -p$mysqlrootpwd -h localhost <  /tmp/mysql_sec_script
#rm -f /tmp/mysql_sec_script
/etc/init .d /mysqld  restart
source  /etc/profile
echo  "============================MariaDB 10.1.16 install completed========================="
}
function  CheckInstall()
{
echo  "===================================== Check install ==================================="
clear
ismysql= ""
echo  "Checking..."
if  [ -s  /usr/local/mysql/bin/mysql  ] && [ -s  /usr/local/mysql/bin/mysqld_safe  ] && [ -s  /etc/my .cnf ];  then
   echo  "MySQL: OK"
   ismysql= "ok"
   else
   echo  "Error: /usr/local/mysql not found!!!MySQL install failed."
fi
if  "$ismysql"  "ok"  ];  then
echo  "Install MariaDB 10.1.16 completed! enjoy it."
echo  "========================================================================="
netstat  -ntl
else
echo  "Sorry,Failed to install MySQL!"
echo  "You can tail /root/mysql-install.log from your server."
fi
}
#The installation log
InitInstall 2>&1 |  tee  /root/mysql-install .log
CheckAndDownloadFiles 2>&1 |  tee  -a  /root/mysql-install .log
InstallDependsAndOpt 2>&1 |  tee  -a  /root/mysql-install .log
InstallMySQL56 2>&1 |  tee  -a  /root/mysql-install .log
CheckInstall 2>&1 |  tee  -a  /root/mysql-install .log





 [root@HE3 ~]# mysql -uroot -p
Enter password: 
Welcome to the MariaDB monitor.  Commands end with ; or \g.
Your MariaDB connection id is 6
Server version: 10.1.16-MariaDB MariaDB Server

Copyright (c) 2000, 2016, Oracle, MariaDB Corporation Ab and others.

Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

MariaDB [(none)]> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| mysql              |
| performance_schema |
| test               |
+--------------------+
4 rows in set (0.00 sec)




至此,mariadb-10.1.16安装成功








 本文转自 dbapower 51CTO博客,原文链接:http://blog.51cto.com/suifu/1830575,如需转载请自行联系原作者

相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
4月前
|
人工智能 Kubernetes jenkins
容器化AI模型的持续集成与持续交付(CI/CD):自动化模型更新与部署
在前几篇文章中,我们探讨了容器化AI模型的部署、监控、弹性伸缩及安全防护。为加速模型迭代以适应新数据和业务需求,需实现容器化AI模型的持续集成与持续交付(CI/CD)。CI/CD通过自动化构建、测试和部署流程,提高模型更新速度和质量,降低部署风险,增强团队协作。使用Jenkins和Kubernetes可构建高效CI/CD流水线,自动化模型开发和部署,确保环境一致性并提升整体效率。
|
1月前
|
JavaScript 搜索推荐 前端开发
通义灵码2.5智能体模式联合MCP:打造自动化菜品推荐平台,实现从需求到部署的全流程创新
本项目利用通义灵码2.5的智能体模式与MCP服务,构建在线点餐推荐网站。基于Qwen3模型,实现从需求到代码生成的全流程自动化,集成“今天吃什么”和EdgeOne MCP服务,提供个性化推荐、偏好管理等功能。技术架构采用React/Vue.js前端与Node.js后端,结合MCP工具链简化开发。项目涵盖功能测试、部署及未来扩展方向,如餐厅推荐、语音交互等,展示高效开发与灵活扩展能力。
|
6月前
|
存储 人工智能 自然语言处理
ChatMCP:基于 MCP 协议开发的 AI 聊天客户端,支持多语言和自动化安装 MCP 服务器
ChatMCP 是一款基于模型上下文协议(MCP)的 AI 聊天客户端,支持多语言和自动化安装。它能够与多种大型语言模型(LLM)如 OpenAI、Claude 和 OLLama 等进行交互,具备自动化安装 MCP 服务器、SSE 传输支持、自动选择服务器、聊天记录管理等功能。
2021 16
ChatMCP:基于 MCP 协议开发的 AI 聊天客户端,支持多语言和自动化安装 MCP 服务器
|
6月前
|
Serverless 决策智能 UED
构建全天候自动化智能导购助手:从部署者的视角审视Multi-Agent架构解决方案
在构建基于多代理系统(Multi-Agent System, MAS)的智能导购助手过程中,作为部署者,我体验到了从初步接触到深入理解再到实际应用的一系列步骤。整个部署过程得到了充分的引导和支持,文档详尽全面,使得部署顺利完成,未遇到明显的报错或异常情况。尽管初次尝试时对某些复杂配置环节需反复确认,但整体流程顺畅。
138 3
|
6月前
|
运维 jenkins Java
Jenkins 自动化局域网管控软件构建与部署流程
在企业局域网管理中,Jenkins 作为自动化工具,通过配置源码管理、构建及部署步骤,实现了高效、稳定的软件开发与部署流程,显著提升局域网管控软件的开发与运维效率。
124 5
|
7月前
|
敏捷开发 Devops 测试技术
自动化测试中的持续集成与持续部署
在现代软件开发实践中,自动化测试是确保软件质量和快速迭代的关键。本文将探讨自动化测试如何与持续集成(CI)和持续部署(CD)流程相结合,以提高开发效率和软件质量。我们将分析CI/CD管道中自动化测试的最佳实践,以及如何克服实施过程中的挑战。
98 6
|
7月前
|
jenkins Java 持续交付
软件开发自动化程度的不断提高,持续集成(CI)和持续部署(CD)成为现代软件开发的重要组成部分
随着软件开发自动化程度的不断提高,持续集成(CI)和持续部署(CD)成为现代软件开发的重要组成部分。本文以电商公司为例,介绍如何使用 Jenkins 自动发布 Java 代码,包括安装配置、构建脚本编写及自动化部署等步骤,帮助团队实现高效稳定的软件交付。
86 3
|
8月前
|
运维 监控 Devops
DevOps实践:持续集成与部署的自动化之旅
【10月更文挑战第7天】在软件开发领域,DevOps已成为提升效率、加速交付和确保质量的关键策略。本文将深入探讨如何通过实施持续集成(CI)和持续部署(CD)来自动化开发流程,从而优化运维工作。我们将从基础概念入手,逐步过渡到实际操作,包括工具选择、流程设计以及监控和反馈机制的建立。最终,我们不仅会展示如何实现这一自动化流程,还会讨论如何克服常见的挑战,以确保成功实施。
127 9
|
8月前
|
SQL 分布式计算 Hadoop
Hadoop-12-Hive 基本介绍 下载安装配置 MariaDB安装 3台云服务Hadoop集群 架构图 对比SQL HQL
Hadoop-12-Hive 基本介绍 下载安装配置 MariaDB安装 3台云服务Hadoop集群 架构图 对比SQL HQL
227 3
|
9月前
|
Devops jenkins Java
DevOps实践:持续集成和部署的自动化之旅
【9月更文挑战第20天】在软件开发的世界里,速度和质量是至关重要的。本文将带领读者踏上一场自动化之旅,深入探索DevOps文化中的两大支柱——持续集成(CI)和持续部署(CD)。我们将通过一个实际的案例,展示如何利用现代工具和技术实现代码从编写到部署的无缝转换,确保软件交付的高效性和可靠性。准备好让你的开发流程变得更加流畅和高效了吗?让我们开始吧!

热门文章

最新文章

推荐镜像

更多