Last active
November 24, 2020 06:21
-
-
Save Lewiscowles1986/27cfeda001bb75a9151b5c974c2318bc to your computer and use it in GitHub Desktop.
Raspberry Pi MariaDB 10.1 with Galera Cluster build
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
#!/bin/bash | |
if [ "$EUID" -ne 0 ] | |
then echo "Must be root" | |
exit | |
fi | |
apt-get update -y | |
apt-get upgrade -y | |
apt-get dist-upgrade -y | |
apt-get install -y build-essential git cmake scons rpi-update | |
apt-get install -y libarchive-dev libevent-dev libssl-dev libboost-dev | |
apt-get install -y libncurses5-dev libbison-dev | |
cd /tmp | |
git clone -b 10.1 https://github.com/MariaDB/server.git --depth=1 mariadb-server-src | |
cd mariadb-server-src | |
cmake -DWITH_WSREP=ON -DWITH_INNODB_DISALLOW_WRITES=ON ./ | |
make | |
make install | |
cp /usr/local/mysql/support-files/mysql.server /etc/init.d/mysqld | |
update-rc.d mysqld defaults | |
echo "export PATH=\${PATH}:/usr/local/mysql/bin/" > /etc/profile.d/mysql | |
groupadd mysql && useradd -g mysql mysql | |
mkdir -p /srv/mysql | |
rm -rf /etc/mysql | |
install -v -dm 755 /etc/mysql && | |
cat > /etc/mysql/my.cnf << "EOF" | |
# Begin /etc/mysql/my.cnf | |
# The following options will be passed to all MySQL clients | |
[client] | |
#password = your_password | |
port = 3306 | |
socket = /run/mysqld/mysqld.sock | |
# The MySQL server | |
[mysqld] | |
port = 3306 | |
socket = /run/mysqld/mysqld.sock | |
datadir = /srv/mysql | |
skip-external-locking | |
key_buffer_size = 16M | |
max_allowed_packet = 1M | |
sort_buffer_size = 512K | |
net_buffer_length = 16K | |
myisam_sort_buffer_size = 8M | |
# Don't listen on a TCP/IP port at all. | |
skip-networking | |
# required unique id between 1 and 2^32 - 1 | |
server-id = 1 | |
# Uncomment the following if you are using BDB tables | |
#bdb_cache_size = 4M | |
#bdb_max_lock = 10000 | |
# InnoDB tables are now used by default | |
innodb_data_home_dir = /srv/mysql | |
innodb_data_file_path = ibdata1:10M:autoextend | |
innodb_log_group_home_dir = /srv/mysql | |
# You can set .._buffer_pool_size up to 50 - 80 % | |
# of RAM but beware of setting memory usage too high | |
innodb_buffer_pool_size = 16M | |
innodb_additional_mem_pool_size = 2M | |
# Set .._log_file_size to 25 % of buffer pool size | |
innodb_log_file_size = 5M | |
innodb_log_buffer_size = 8M | |
innodb_flush_log_at_trx_commit = 1 | |
innodb_lock_wait_timeout = 50 | |
[mysqldump] | |
quick | |
max_allowed_packet = 16M | |
[mysql] | |
no-auto-rehash | |
# Remove the next comment character if you are not familiar with SQL | |
#safe-updates | |
[isamchk] | |
key_buffer = 20M | |
sort_buffer_size = 20M | |
read_buffer = 2M | |
write_buffer = 2M | |
[myisamchk] | |
key_buffer_size = 20M | |
sort_buffer_size = 20M | |
read_buffer = 2M | |
write_buffer = 2M | |
[mysqlhotcopy] | |
interactive-timeout | |
# End /etc/mysql/my.cnf | |
EOF | |
source /etc/profile.d/mysql | |
/usr/local/mysql/scripts/mysql_install_db --user=mysql --datadir=/srv/mysql --basedir=/usr/local/mysql | |
chown -R mysql:mysql /srv/mysql | |
apt-get install -y libboost-program-options-dev check | |
cd /tmp | |
git clone https://github.com/codership/galera --depth=1 | |
cd galera | |
scons | |
if [ -d "/etc/php/7.0" ]; then | |
apt-get install -y php7.0-mysql | |
fi | |
Is there any tutorial website for same ?
This is so old now, you should really not use. It's 4 years old and we've had 2-3 major OS updates since then MariaDB 10.1 is OLD
What parts of this was it you needed?
Actually I want to set up multiple Raspberry Pi over a lan with static IP on all. Data entered on any one shall be replicated on all. For some alarm system project in my college.
Right, none of that has anything to do with this...
Someone on Facebook did point to this blog while I put my requirements there
FYI future visitors galera is part of mariadb-server from mariadb version 10.4 onwards
Thx @sanfx, this is from 2016
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
I am facing with this error .....plz help me....only complete 5%....working with RPI3