制作 mysql的rpm文件_自制mysql.rpm安装包

RPM安装比源码更快更方便,更利于统一版本,省去了繁琐的编译过程,下面以制作mysql的rpm安装包为例。

编译环境

1、 安装rpm-build;

检查是否配置rpm环境

8f900a89c6347c561fdf2122f13be562.png

961ddebeb323a10fe0623af514929fc1.png

1 # sudo yum list | greprpm2 This system is not registered with RHN.3 RHN support will be disabled.4 redhat-rpm-config.noarch 8.0.45-32.el5 installed5 rpm.x86_64 4.4.2.3-22.el5 installed6 rpm-build.x86_64 4.4.2.3-22.el5 installed7 rpm-libs.x86_64 4.4.2.3-22.el5 installed8 rpm-python.x86_64 4.4.2.3-22.el5 installed

View Code

若未安装则:

# sudo yum install rpm-build

2、创建rpm编译目录

(1)选定目录,选择一个可进行写操作的目录,这里选择根目录/home/wyett;

(2)进入目录,创建如下文件夹

8f900a89c6347c561fdf2122f13be562.png

961ddebeb323a10fe0623af514929fc1.png

1 # cd /home/wyett2 # sudo mkdirmysql3 # cd mysql4 # sudo mkdir BUILD RPMS SOURCES SPECS SRPMS

View Code

BUILD //解压后的tar.gz包

RPMS  //编译后的RPM

SOURCES //放编译需要的文件mysql-xxx.tar.gz,*.cnf

SPECS //*.spec编译脚本

SRPMS //src格式的rpm包存放的位置

3、预先准备mysql-x.x.x.tar.gz源码安装包,下载地址:http://downloads.mysql.com/archives/community/,放在/home/wyett/mysql/SOURCES/下面。

4、准备mysql-company-xxx.spec文件,放在/home/wyett/mysql/SPECS/目录下面

这样,编译环境部署完成,目录结构如下:

8f900a89c6347c561fdf2122f13be562.png

961ddebeb323a10fe0623af514929fc1.png

1 # pwd

2 /home/wyett/mysql3 # tree4 .5 |--BUILD6 |--RPMS7 |--SOURCES8 | `-- mysql-xxx.tar.gz9 |--SPECS10 | |-- mysql-xxx-xxx.spec11 | `-- mysql-xxx-xxx.spec12 `-- SRPMS

View Code

准备spec文件

Spec文件包括三部分,introduction section,编译部分,files部分;

1、introduction section部分,包括一些变量定义:

8f900a89c6347c561fdf2122f13be562.png

961ddebeb323a10fe0623af514929fc1.png

1 ###################################################2 #File name:mysql-company-x.x.x-release.x86_64.spec3 #Author :wyett4 #Date :Oct 15,2013

5 #6 ###################################################7

8 %define _topdir /home/wyett/mysql9 %define name mysql10 %define version x.x.x11 %define release dba.4

12 %define serial 1

13 %define userpath /usr/local/mysql14 %define myusr mysql15 %define mygrp mysql16 %define buildroot %{_topdir}/%{name}-%{version}-%{release}-root-%(%{__id_u} -n)17

18 BuildRoot:%{buildroot}19 Summary:Mysql.rmp package of the company20 License:GPL21 Name:%{name}22 Version:%{version}23 Release:%{release}24 Vendor:Mysql package of the company25 Url:http://www.company.com/

26 SOURCE0:%{name}-%{version}.tar.gz27 #SOURCE1:my3306.cnf28 BuildRequires:ncurses-devel29 Group:Application/Databases

View Code

%define这部分变量可以自己指定,不要也可以,不过定义后修改方便,其中:

_topdir 定义了rpm工作的根目录,上文中提到,需要有写权限

Buildroot 定义了rpm包安装后的根目录,相当于咱们编译安装的 /目录,rpm打包就打包这部分;

下面部分需要注意:

BuildRoot:%{buildroot}              //编译安装的根目录

SOURCE0:%{name}-%{version}.tar.gz      //tar包

SOURCE1:my3306.cnf               //配置文件

BuildRequires:ncurses-devel                              //mysql编译安装时需要的环境包

2、编译部分,包括

%description             文字性描述

%prep                      包括解压命令和其他一些shell脚本

%setup –q                解压tar包到BUILD目录

%build                      预编译,如果再需要重新编译,修改这部分就行

./configure

Make

%setup                     安装,安装到BuildRoot(即${RPM_BUILD_ROOT})目录下

%clean                      清理一些编译过程的目录

%file                         需要打包的文件目录

8f900a89c6347c561fdf2122f13be562.png

961ddebeb323a10fe0623af514929fc1.png

1 %description2 The rpm package forthe company3

4 %prep5 %setup-q -n %{name}-%{version}6

7 %build8 ./configure \9 --prefix=%{userpath} \10 --with-comment=Source \11 --with-server-suffix=-enterprise-gpl \12 --with-mysqld-user=mysql \13 --without-debug \14 --with-charset=latin1 \15 --with-extra-charsets=big5,ascii,gb2312,gbk,utf8 \16 --with-client-ldflags=-all-static \17 --with-mysqld-ldflags=-all-static \18 --with-plugins=csv,innobase,myisam,heap,partition \19 --enable-local-infile20 make -j 8

21

22

23 %install

24 if

25 getent group %mygrp >/dev/null

26 then

27 : OK group %mygrp already present28 else

29 /usr/sbin/groupadd -r %mygrp 2>/dev/null ||:30 fi

31 if

32 id %myusr > /dev/null 2>&1

33 then

34 : OK user %myusr already present35 else

36 /usr/sbin/useradd -g %mygrp -s /sbin/nologin -c "User for Mysql" -d /var/tmp %myusr 2> /dev/null ||:37 fi

38 if ! [ -d %{buildroot}/mysqldata ]39 then

40 %{__mkdir} -p %{buildroot}/mysqldata41 fi

42

43 make install DESTDIR=%{buildroot} INSTALLDIRS=vendor44 install -m 755 %{SOURCE1} %{buildroot}/mysqldata/mysql/data/mysql3306/my3306_master.cnf45 #install

46 %{__rm} -rf %{buildroot}/usr/local/mysql/sql-bench47 %{__rm} -rf %{buildroot}/usr/local/mysql/mysql-test48

49

50 %clean51 %post52

53 if

54 getent group %mygrp >/dev/null

55 then

56 : OK group %mygrp already present57 else

58 /usr/sbin/groupadd -r %mygrp 2>/dev/null ||:59 fi

60 if

61 id %myusr > /dev/null 2>&1

62 then

63 : OK user %myusr already present64 else

65 /usr/sbin/useradd -g %mygrp -s /sbin/nologin -c "User for Mysql" -d /var/tmp %myusr 2> /dev/null ||:66 fi

67 /usr/local/mysql/bin/mysql_install_db --user=mysql --datadir=/mysqldata/mysql/data/mysql330668 chown mysql:mysql /mysqldata -R

View Code

注:在mysql 5.5及以上版本中,不再对./configure支持,需要cmake进行编译安装,相关参数请参考:

http://blog.csdn.net/seteor/article/details/7249513

3、生成rpm包的打包目录,默认BUILDROOT目录,无法修改

8f900a89c6347c561fdf2122f13be562.png

961ddebeb323a10fe0623af514929fc1.png

1 %files2 %defattr (-,root,root)3 %{userpath}/

4 /mysqldata

View Code

生成rpm包

rpmbuild命令,过程可以分阶段

-bb    制作成二进制                               // # sudo rpmbuild –bb mysql.spec

-bs    源码形式

-ba    源码和二进制两种形式

-bl    制作后检测buildroot生成但没有包含到rpm包中的文件,注意如果生成未包含进去会出错

-bc    只执行到%

-bi    只执行到%install段

-bp    只执行到%prep段

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/552412.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

mysql远程授权格式_MySQL远程访问授权

开启 MySQL 的远程登陆帐号有两大步:1、确定服务器上的防火墙没有阻止 3306 端口。MySQL 默认的端口是 3306 ,需要确定防火墙没有阻止 3306 端口,否则远程是无法通过 3306 端口连接到 MySQL 的。如果您在安装 MySQL 时指定了其他端口&#xf…

mysql multi主从复制_mysqld_multi方式配置Mysql数据库主从复制

mysqld_multi设计用于管理在同一台机器上运行的多个mysqld进程,这些进程使用不同的socket文件并监听在不同的端口上。mysqld_multi可以批量启动、关闭、或者报告这些mysqld进程的状态。在这里我们通过这种方式来在同一个机器上启动多个数据库实例,并配置…

mysql 日志节点恢复_基于binlog二进制日志的MySQL恢复笔记

基于binlog二进制日志的MySQL恢复笔记刚好复习到这里,顺手做个小实验,记录下。总的操作流程:step0、关掉数据库的对外访问【防止用户操作继续写入这个库】step1、mysqlbinlog 导出相关时间段数据库的二进制日志step2、编辑today.sql找到误操作…

mysql中if在oracle怎么用_mysql和oracle的mybatis操作

1.Oracle、MySQL插入时返回下一个主键的操作Xml代码 Oracle:SELECT SEQ_ROLE.NEXTVAL AS ID FROM DUALinsert into ROLE(ID, NAME, CREATE, MODIFY) values (#{id}, #{name}, sysdate, sysdate)注意:这边的keyProperty"id"中"id"指的…

mysql数据库的三级模式_2016年计算机三级MySQL数据库试题

2016年计算机三级MySQL数据库试题一、选择题1.E-R图提供了表示信息世界中实体、属性和________的方法。A.数据B.联系C.表D.模式2.数据库系统的核心是________。A.数据模型B.数据库管理系统C.数据库D.数据库管理员3.E-R图是数据库设计的工具之一,它一般适用于建立数据…

python对角线图_python对角线图_python – 在Seaborn Jointplot上绘制对角线(相等的线)...

错误是一个有用的暗示:JointPlot是子图的集合,你必须找到特定的斧头来绘制.修改Seaborn示例:import numpy as npimport pandas as pdimport seaborn as snsfrom matplotlib.pyplot import showsns.set(style"white")# Generate a random corre…

python编程求极限_Sympy笔记一

from IPython.display import displayfrom sympy import *前置知识理解这份笔记的内容需,读者需要具备基础的python知识并且对函数,微积分和矩阵有一定的基础。辅助函数由于后面的笔记中, 我们会大量将一个Sympy object和应用某个函数之后&am…

python语言逆序符号_python的逆序

下面的代码片段可以帮助您完成最后一个任务。如果在字符串的开始或结尾之外的其他地方发现了特殊字符,则对于子集的恢复没有特殊处理。在# Special chars which should be ignored for revertingSPECIALCHARS [ , ., ,]def reverse( string_ ):# Find occurence of…

wpf mysql存储过程_MySQL存储过程的创建及调用

# SQL语句:先编译后执行存储过程(Stored Procedure):一组可编程的函数,是为了完成特定功能的SQL语句集,经编译创建并保存在数据库中,用户可通过指定存储过程的名字并给定参数(需要时)来调用执行。优点(为什么要用存储过…

mysql没加引号导致全表扫描_mysql隐蔽的索引规则导致数据全表扫描

索引是为了加速数据的检索,但是不合理的表结构或适应不当则会起到反作用。我们在项目中就遇到过类似的问题,两个十万级别的数据表,在做连接查询的时候,查询时间达到了7000多秒还没有查出结果。首先说明,关联的字段都已…

python123测验7程序题答案_Python语言程序设计 Python123 测验7: 文件和数据格式化(编程题)...

版权声明:本文为博主原创文章,遵循CC 4.0 by-sa版权协议,转载请附上原文出处链接和本声明。本文链接:https://blog.csdn.net/weixin_42067082/article/details/97661863文本的平均列数描述:打印输出附件文件的平均列数…

mysql 多个密码登录_mysql 多实例登录密码测试

最近在做mysql 多实例的时候,采用不同的方式登录mysql数据库,发现mysql -uroot -p -h 127.0.0.1 -P3308 ,登录时居然不要密码就可以登录,吓得我一身汗,经过检查终于找到原因记录下来,给小白们参考。[rootmy…

设置MySQL排序方式_设置MySQL设置字符集和排序方式

1. 编辑/etc/my.cnf文件, 在"[client]"下添加"default-character-setutf8"2. 编辑/etc/my.cnf文件, 在"[mysqld]"下添加"default-character-setutf8"3. 重新启动mysql服务# sudo /etc/init.d/mysqld restart* 查看系统字符集和排序方式…

redhat5.4 安装mysql_Linux redhat 5.4上安装MYDNS

Linux redhat 5.4上安装MYDNS一、1,MYDNS 的简介:MyDNS是一个UNIX平台下的免费DNS服务器端软件。它被设计成直接从数据库中读取DNS记录软件,并且修改记录后也可时时生效。在MyDNS上,你可随心所欲地增加你自己的次级域名的同时建站…

mysql 5.7 flashback_Flashback for MySQL 5.7

实现原理flashback的概念最早出现于Oracle数据库,用于快速恢复用户的误操作。flashback for MySQL用于恢复由DML语句引起的误操作,目前不支持DDL语句。例如下面的语句:DELETE FROM XXX;UPDATE XXX SET YYYZZZ;若没有flashback功能&#xff0c…

给mysql数据库设计编码_MYSQL数据库编码原理

很多站长可能与织梦CMS小编一样,觉得MYSQL数据库即熟悉又神秘。熟悉是因为我们每天都会用到MYSQL进行安装织梦程序,陌生是因为mysql经常与linux联系,是基于linux系统的下的应用,而我们平常使用的都是windows主机系统。织梦CMS就基…

Java2精要_java知识精要(一)

一、java数组 (疯狂java讲义 第4.5 ~ 4.6章节)1) 声明形式:type[] arrayName; 推荐方式type arrayName[];2) 初始化:方式一:type[] arrayName;arrayName new type[] {element1, element2, element3, ...}方式二:type[] arrayName…

java的反射机制是什么_JAVA反射机制

一、什么是反射机制 简单的来说,反射机制指的是程序在运行时能够获取自身的信息。在java中,只要给定类的名字,那么就可以通过反射机制来获得类的所有信息。二、哪里用到反射机制 有些时候,我们用过一些知识&#xf…

java dot画图_小O的图案 (Java代码)(最简单的解法)

解题思路:注意事项:参考代码:import java.util.Scanner;public class C1788 {public static void main(String[] args) {Scanner sc new Scanner(System.in);while (sc.hasNext()) {F(sc.nextInt());}sc.close();}private static void F(int n){System.out.println(n);int len…

java inireader_java读取配置文件 Java中如何设置读取ini配置文件?

Java读取配置文件的几种方法以及路径问题看透,心静,锁份幽静,将自己填埋在那里,任窗外灯红酒绿,草长莺飞,让那颗疲惫的心,静静地栖息在流水盈盈里,抛却尘世累累。java 怎么读取web j…