MySQL集群自动安装脚本_MySQL
Mysql集群
1. 在MySQL源代码目录下新建脚本 install.sh,把下面的代码添加到这个脚本中:
#!/bin/bash
############################################
######### MySQL Server Config ##############
############################################
#Determine to install MySQL server
#"0" means do not install server programs
INST_SERVER=1
#MySQL installation path
INST_PATH="/usr/local/mysql"
#Define the ports of MySQL installation, intput strings of
#PORT with whitespace separated.
#e.g. "3306 3307" means install two MySQL servers:
# The first server will be installed to $INST_PATH/1 and listen 3306 port.
# The second server will be installed to $INST_PATH/2 and listen 3307 port.
# ... ...
INST_PORTS="3306"
#The management server information
MGM_HOST="192.168.1.253"
MGM_PORT="2200"
###########################################
######### MySQL Cluster Config ############
###########################################
#Determine to install cluster
#"0" means do not install cluster programs
INST_CLUSTER=1
#Define COMPUTERs in config.ini, intput strings of HostName with
#whitespace separated.
#The Id attribute is auto increment and start with 1.
#e.g. "192.168.1.253 192.168.252" will generate the following code
# [COMPUTER]
# Id=1
# HostName=192.168.1.253
# [COMPUTER]
# Id=2
# HostName=192.168.1.252
COMPUTERS="192.168.1.253 192.168.1.252"
#Define MGMs in config.ini, intput strings of HostName with whitespace separated.
#e.g. "192.168.1.253 192.168.252" will generate the following code
# [MGM]
# HostName=192.168.1.253
# [MGM]
# HostName=192.168.1.252
MGMS="192.168.1.253"
#Define DBs in config.ini, intput ids of ExecuteOnComputer with whitespace separated.
#e.g. "1 2" will generate the following code
# [DB]
# ExecuteOnComputer=1
# [DB]
# ExecuteOnComputer=2
DBS="1"
#Define APIs in config.ini, intput ids of ExecuteOnComputer with whitespace separated.
#e.g. "1 0 1 2" will generate the following code
# [API]
# ExecuteOnComputer=1
# [API]
# [API]
# ExecuteOnComputer=1
# [API]
# ExecuteOnComputer=2
APIS="1 0 2 2"
######################################################################
########## Starting to install programs, do not modify them! #########
######################################################################
echo "Starting to install programs" > install.log
#Find installation path
if [ $# -gt 0 ]
then
INST_PATH="{GetProperty(Content)}"
else
INST_PATH="/usr/local/mysql"
fi
if [ 0 -lt $INST_SERVER ]
then
echo "Now, installing the MySQL servers..."
#Loop to install mysql servers
INSTALLED_SERVER_COUNT=1
for PORT in $INST_PORTS
do
#Define the current mysql server installation path
MYSL_PATH=$INST_PATH/$INSTALLED_SERVER_COUNT
#Configure mysql server
echo "Exec ./configure --prefix=$MYSL_PATH --with-pthread
--with-unix-socket-path=$MYSL_PATH/var/mysql.sock --with-mysqld-user=root
--with-tcp-port=$PORT --with-charset=gbk --with-ndbcluster" >> install.log
./configure --prefix=$MYSL_PATH --with-pthread
--with-unix-socket-path=$MYSL_PATH/var/mysql.sock
--with-mysqld-user=root --with-tcp-port=$PORT
--with-charset=gbk --with-ndbcluster
#Make mysql server
echo "Exec make && make install" >> install.log
make && make install
#Create var directory for mysql data
mkdir -p $MYSL_PATH/var
#Create my.cnf
echo "Create $MYSL_PATH/var/my.cnf" >> install.log
echo "[client]" > $MYSL_PATH/var/my.cnf
echo "port=$PORT" >> $MYSL_PATH/var/my.cnf
echo "socket=$MYSL_PATH/var/mysql.sock" >> $MYSL_PATH/var/my.cnf
echo "" >> $MYSL_PATH/var/my.cnf
echo "[mysqld]" >> $MYSL_PATH/var/my.cnf
echo "ndbcluster" >> $MYSL_PATH/var/my.cnf
echo "ndb_connectstring=host=$MGM_HOST:$MGM_PORT" >> $MYSL_PATH/var/my.cnf
echo "user=root" >> $MYSL_PATH/var/my.cnf
echo "port=$PORT" >> $MYSL_PATH/var/my.cnf
echo "basedir=$MYSL_PATH/" >> $MYSL_PATH/var/my.cnf
echo "datadir=$MYSL_PATH/var/" >> $MYSL_PATH/var/my.cnf
echo "socket=$MYSL_PATH/var/mysql.sock" >> $MYSL_PATH/var/my.cnf
echo "default-character-set=gbk" >> $MYSL_PATH/var/my.cnf
echo "default-storage-engine=INNODB" >> $MYSL_PATH/var/my.cnf
echo "max_connections=500" >> $MYSL_PATH/var/my.cnf
echo "" >> $MYSL_PATH/var/my.cnf
echo "query_cache_size=33M" >> $MYSL_PATH/var/my.cnf
echo "table_cache=1520" >> $MYSL_PATH/var/my.cnf
echo "tmp_table_size=16M" >> $MYSL_PATH/var/my.cnf
echo "thread_cache=38" >> $MYSL_PATH/var/my.cnf
echo "" >> $MYSL_PATH/var/my.cnf
echo "#MyISAM Specific options" >> $MYSL_PATH/var/my.cnf
echo "#skip-myisam" >> $MYSL_PATH/var/my.cnf
echo "" >> $MYSL_PATH/var/my.cnf
echo "#INNODB Specific options" >> $MYSL_PATH/var/my.cnf
echo "#skip-innodb" >> $MYSL_PATH/var/my.cnf
chmod 755 $MYSL_PATH/var/my.cnf
#Install mysql database
echo "Exec $MYSL_PATH/bin/mysql_install_db" >> install.log
$MYSL_PATH/bin/mysql_install_db
#Create mysql control script
if [ -e $MYSL_PATH/share/mysql/mysql.server ]
then
#Use default mysql control script
#Create mysql server start script
echo "Create $MYSL_PATH/start" >> install.log
echo "$MYSL_PATH/share/mysql/mysql.server start" > $MYSL_PATH/start
echo "Chmod 755 $MYSL_PATH/start" >> install.log
chmod 755 $MYSL_PATH/start
#Create mysql server stop script
echo "Create $MYSL_PATH/stop" >> install.log
echo "$MYSL_PATH/share/mysql/mysql.server stop" > $MYSL_PATH/stop
echo "Chmod 755 $MYSL_PATH/stop" >> install.log
chmod 755 $MYSL_PATH/stop
#Create mysql server restart script
echo "Create $MYSL_PATH/restart" >> install.log
echo "$MYSL_PATH/share/mysql/mysql.server restart" > $MYSL_PATH/restart
echo "Chmod 755 $MYSL_PATH/restart" >> install.log
chmod 755 $MYSL_PATH/restart
else
#Use custom mysql control script
#Create mysql server start script
echo "Create $MYSL_PATH/start" >> install.log
echo "$MYSL_PATH/libexec/mysqld &" > $MYSL_PATH/start
echo "Chmod 755 $MYSL_PATH/start" >> install.log
chmod 755 $MYSL_PATH/start
#Create mysql server stop script
echo "Create $MYSL_PATH/stop" >> install.log
echo "$MYSL_PATH/bin/mysqladmin -u root -p shutdown" > $MYSL_PATH/stop
echo "Chmod 755 $MYSL_PATH/stop" >> install.log
chmod 755 $MYSL_PATH/stop
#Create mysql server restart script
echo "Create $MYSL_PATH/restart" >> install.log
echo "$MYSL_PATH/bin/mysqladmin -u root -p shutdown" > $MYSL_PATH/restart
echo "$MYSL_PATH/libexec/mysqld &" >> $MYSL_PATH/restart
echo "Chmod 755 $MYSL_PATH/restart" >> install.log
chmod 755 $MYSL_PATH/restart
fi
#Clean mysql server to get ready for the next installation
echo "Exec make clean" >> install.log
make clean
INSTALLED_SERVER_COUNT=$(($INSTALLED_SERVER_COUNT + 1))
done
echo "Configurations! MySQL servers has been installed successfully."
echo ""
echo "1. To start mysql server, use the following command:"

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

Solution to the problem that Win11 system cannot install Chinese language pack With the launch of Windows 11 system, many users began to upgrade their operating system to experience new functions and interfaces. However, some users found that they were unable to install the Chinese language pack after upgrading, which troubled their experience. In this article, we will discuss the reasons why Win11 system cannot install the Chinese language pack and provide some solutions to help users solve this problem. Cause Analysis First, let us analyze the inability of Win11 system to

You may not be able to install guest additions to a virtual machine in OracleVirtualBox. When we click on Devices>InstallGuestAdditionsCDImage, it just throws an error as shown below: VirtualBox - Error: Unable to insert virtual disc C: Programming FilesOracleVirtualBoxVBoxGuestAdditions.iso into ubuntu machine In this post we will understand what happens when you What to do when you can't install guest additions in VirtualBox. Unable to install guest additions in VirtualBox If you can't install it in Virtua

If you have successfully downloaded the installation file of Baidu Netdisk, but cannot install it normally, it may be that there is an error in the integrity of the software file or there is a problem with the residual files and registry entries. Let this site take care of it for users. Let’s introduce the analysis of the problem that Baidu Netdisk is successfully downloaded but cannot be installed. Analysis of the problem that Baidu Netdisk downloaded successfully but could not be installed 1. Check the integrity of the installation file: Make sure that the downloaded installation file is complete and not damaged. You can download it again, or try to download the installation file from another trusted source. 2. Turn off anti-virus software and firewall: Some anti-virus software or firewall programs may prevent the installation program from running properly. Try disabling or exiting the anti-virus software and firewall, then re-run the installation

To update the curl version under Linux, you can follow the steps below: Check the current curl version: First, you need to determine the curl version installed in the current system. Open a terminal and execute the following command: curl --version This command will display the current curl version information. Confirm available curl version: Before updating curl, you need to confirm the latest version available. You can visit curl's official website (curl.haxx.se) or related software sources to find the latest version of curl. Download the curl source code: Using curl or a browser, download the source code file for the curl version of your choice (usually .tar.gz or .tar.bz2

Installing Android applications on Linux has always been a concern for many users. Especially for Linux users who like to use Android applications, it is very important to master how to install Android applications on Linux systems. Although running Android applications directly on Linux is not as simple as on the Android platform, by using emulators or third-party tools, we can still happily enjoy Android applications on Linux. The following will introduce how to install Android applications on Linux systems.

If you have used Docker, you must understand daemons, containers, and their functions. A daemon is a service that runs in the background when a container is already in use in any system. Podman is a free management tool for managing and creating containers without relying on any daemon such as Docker. Therefore, it has advantages in managing containers without the need for long-term backend services. Additionally, Podman does not require root-level permissions to be used. This guide discusses in detail how to install Podman on Ubuntu24. To update the system, we first need to update the system and open the Terminal shell of Ubuntu24. During both installation and upgrade processes, we need to use the command line. a simple

While studying in high school, some students take very clear and accurate notes, taking more notes than others in the same class. For some, note-taking is a hobby, while for others, it is a necessity when they easily forget small information about anything important. Microsoft's NTFS application is particularly useful for students who wish to save important notes beyond regular lectures. In this article, we will describe the installation of Ubuntu applications on Ubuntu24. Updating the Ubuntu System Before installing the Ubuntu installer, on Ubuntu24 we need to ensure that the newly configured system has been updated. We can use the most famous "a" in Ubuntu system

Many novice friends still don’t know how to install creo, so the editor below brings relevant tutorials on creo installation. Friends in need should take a look at it. I hope it can help you. 1. Open the downloaded installation package and find the License folder, as shown in the figure below: 2. Then copy it to the directory on the C drive, as shown in the figure below: 3. Double-click to enter and see if there is a license file, as shown below As shown in the picture: 4. Then copy the license file to this file, as shown in the following picture: 5. In the PROGRAMFILES file of the C drive, create a new PLC folder, as shown in the following picture: 6. Copy the license file as well Click in, as shown in the figure below: 7. Double-click the installation file of the main program. To install, check the box to install new software.
