|
本文重点是spec文件,其他步骤比较简单,笔者就不写了
- 1.yum安装rpmbuild工具 yum -y install rpm-build
- 2.定义工作目录 vi ~/.rpmmacros
%_topdir /root/rpmbuild #也可以使用其他用户制作
- 3.创建topdir目录
mkdir -pv ~/rpmbuild/{BUILD,BUILDROOT,RPMS,SOURCES,SPECS,SRPMS}
%define MYSQL_USER mysql
%define MYSQL_GROUP mysql
Name: mysql
Version: 5.7.18
Release: msxf_v2
Summary: MySQL-5.7.18 RPM
Group: applications/database
License: GPL
URL: http://www.mysql.com
Source0: mysql-5.7.18.tar.gz
Packager: xxxx@gmail.com
BuildRoot: %{_topdir}/%{name}-%{version}-msxf
BuildRequires: cmake
AutoReqProv: no
%description
MySQL 5.7.18
%prep
%setup -n mysql-%{version}
%build
cmake . -DCMAKE_INSTALL_PREFIX=/usr/local/mysql57 \
-DMYSQL_DATADIR=/home/mysql/mysql3306/data \
-DSYSCONFDIR=/home/mysql/mysql3306 \
-DWITH_INNOBASE_STORAGE_ENGINE=1 \
-DWITH_FEDERATED_STORAGE_ENGINE=1 \
-DWITH_BLACKHOLE_STORAGE_ENGINE=1 \
-DWITH_EXAMPLE_STORAGE_ENGINE=1 \
-DWITH_PARTITION_STORAGE_ENGINE=1 \
-DWITH_PERFSCHEMA_STORAGE_ENGINE=1 \
-DMYSQL_UNIX_ADDR=/home/mysql/mysql3306/mysql3306.sock \
-DDEFAULT_CHARSET=utf8 \
-DDEFAULT_COLLATION=utf8_general_ci \
-DENABLED_LOCAL_INFILE=ON \
-DDOWNLOAD_BOOST=1 \
-DWITH_BOOST=../boost_1_59_0/
make %{?_smp_mflags}
%install
rm -rf %{buildroot}
make install DESTDIR=$RPM_BUILD_ROOT
%pre
IS_CONFIG=$( cat /etc/security/limits.conf | grep mysql | wc -l )
if [ $IS_CONFIG -lt 1 ];then
cat >> /etc/security/limits.conf /proc/sys/vm/swappiness
mkdir -p /home/mysql/mysql3306/{data,log,binlog}
TOTAL_SIZE=$( free -g | grep Mem | awk '{print $2}' )
ALLOC_SIZE=$(( $TOTAL_SIZE * 64 / 100 ))
BUFFER_SIZE=$( echo $ALLOC_SIZE | awk -F. '{print $1}')"G"
SERVER_ID=$( ip addr | grep inet | grep "255 scope global" |head -1|awk '{print $2}'|cut -d "." -f 4|cut -d "/" -f 1 )"3306"
cat > /home/mysql/mysql3306/my.cnf /etc/profile
fi
HAVE_SELF_PATH=$( cat ~/.bash_profile | grep /usr/local/mysql57 | wc -l )
if [ $HAVE_SELF_PATH -lt 1 ];then
echo "export PATH=/usr/local/mysql57/bin:\$PATH" >> ~/.bash_profile
fi
/usr/local/mysql57/bin/mysqld_safe --defaults-file=/home/mysql/mysql3306/my.cnf &
IP_ADDR=$( ip addr | grep inet | grep "255 scope global" |head -1|awk '{print $2}' | cut -d "/" -f 1 )
sleep 10
/usr/local/mysql57/bin/mysql -uroot -S /home/mysql/mysql3306/mysql3306.sock |
|
|