您的位置:首页 > 产品设计 > 产品经理

将定制RPM包加入内部Yum Server

2016-03-02 14:15 537 查看
转载http://dreamway.blog.51cto.com/1281816/1110874

[align=left][/align]
如何定制RPM包
http://dreamway.blog.51cto.com/1281816/1110822
[align=left][/align]

前言:此文以生产案例应用通过HAProxy1.4.22源码包为例定制生成rpm包,并加入内部YUM Server仓库,便于以后的软件包安装
1、制作RPM包linux系统环境
# cat /etc/redhat-release  

CentOS release 5.8 (Final)  

# uname -r  

2.6.18-308.el5  

# uname -m  

x86_64

2、构建前的准备
创建rpmbuild所需的目录结构,通常安装好的Cent0S5.8系统已经创建好目录结构,如下:
# ls /usr/src  

debug kernels redhat  

# ls /usr/src/redhat/  

BUILD RPMS SOURCES SPECS SRPMS

root用户制作RPM包使用/usr/src/redhat/下的目录即可
如果使用普通用户,则手工创建好目录即可,命令如下
# mkdir -p  /home/zxp/{BUILD,RPMS,SOURCES,SPECS,SRPMS}

目录说明
BUILD:   用于编译软件包时,源码的临时存放空间。

RPMS:   制作好的二进制包的输出位置。

SOURCES:  源码的位置。

SPECS:   spec文件存放的位置。

SRPMS:   制作好的源码RPM包的输出位置,该包安装时仍需要先编译。
3、SPEC文件详解
构建一个标准的 RPM 包,就需要在目录SPECS下创建.spec文件,里面包含即将被安装的软件的所有详细信息。然后对这个文本在系统中执行rpmbuild命令,系统会按照.spec内容设置的步骤自动生成最终的 RPM 包。
3.1 SPEC文件 语法详解(以HAProxy为例)
# cat haproxy.spec  

Summary: HA-Proxy is a TCP/HTTP reverse proxy for high availability environments       #软件摘要信息  

Name: haproxy       #软件名称  

Version: 1.4.22     #软件版本

Release: 20130106_hexun_as5  #软件分支版本

License: GPL                 #软件版权

Group: System Environment/Daemons  #软件所属分类

URL: http://haproxy.1wt.eu/       #软件主页

Source0: http://haproxy.1wt.eu/download/1.4/src/%{name}-%{version}.tar.gz #源码位置

BuildRoot: %{_tmppath}/%{name}-%{version}-root  #安装目录

BuildRequires: pcre-devel               #编译依赖软件包

Requires: /sbin/chkconfig, /sbin/service #安装依赖软件包

%description  #软件详细的描述信息

HA-Proxy is a TCP/HTTP reverse proxy which is particularly suited for high  

availability environments. Indeed, it can:  

- route HTTP requests depending on statically assigned cookies  

- spread the load among several servers while assuring server persistence  

 through the use of HTTP cookies  

- switch to backup servers in the event a main one fails  

- accept connections to special ports dedicated to service monitoring  

- stop accepting connections without breaking existing ones  

- add/modify/delete HTTP headers both ways  

- block requests matching a particular pattern  

It needs very little resource. Its event-driven architecture allows it to easily  

handle thousands of simultaneous connections on hundreds of instances without  

risking the system's stability.  

# %prep定义了构建前要做的准备,通常是%setup定义如何解包

%prep        

%setup -q  

# We don't want any perl dependecies in this RPM:  

%define __perl_requires /bin/true #定义不使用perl依赖关系

%build #编译源码命令,通常是./configure && make,根据具体包安装方法而定

%{__make} ARCH=%{_target_cpu} TARGET=linux26  

%install  #安装阶段  

[ "%{buildroot}" != "/" ] && %{__rm} -rf %{buildroot}  

%{__install} -d %{buildroot}%{_sbindir}  

%{__install} -d %{buildroot}%{_sysconfdir}/rc.d/init.d  

%{__install} -d %{buildroot}%{_sysconfdir}/%{name}  

%{__install} -d %{buildroot}%{_mandir}/man1/  

%{__install} -s %{name} %{buildroot}%{_sbindir}/  

%{__install} -c -m 644 examples/%{name}.cfg %{buildroot}%{_sysconfdir}/%{name}/  

%{__install} -c -m 755 examples/%{name}.init %{buildroot}%{_sysconfdir}/rc.d/init.d/%{name}  

%{__install} -c -m 755 doc/%{name}.1 %{buildroot}%{_mandir}/man1/  

%clean  #清理BUILD目录阶段

[ "%{buildroot}" != "/" ] && %{__rm} -rf %{buildroot}  

%post   #安装后制定的脚本

/sbin/chkconfig --add %{name}

%preun #卸载前执行的脚本

if [ $1 = 0 ]; then

 /sbin/service %{name} stop >/dev/null 2>&1 || :  

 /sbin/chkconfig --del %{name}

fi  

%postun  #卸载后执行的脚本

if [ "$1" -ge "1" ]; then

 /sbin/service %{name} condrestart >/dev/null 2>&1 || :  

fi  

%files  #文件列表,主要是设置安装rpm包后的文件、目录属性

%defattr(-,root,root)  #定义默认属性

%doc CHANGELOG TODO examples/*.cfg doc/haproxy-en.txt doc/haproxy-fr.txt doc/architecture.txt doc/configuration.txt #指定软件文档

%doc %{_mandir}/man1/%{name}.1*          #指定man帮助文档  

%attr(0755,root,root) %{_sbindir}/%{name}  #单独指定目录属性  

%dir %{_sysconfdir}/%{name}               #定义软件安装目录  

%attr(0644,root,root) %config(noreplace) %{_sysconfdir}/%{name}/%{name}.cfg   #单独指定文件属性  

%attr(0755,root,root) %config %{_sysconfdir}/rc.d/init.d/%{name} #单独指定文件属性

%changelog   #软件升级日志

* Tue Aug 14 2012 Willy Tarreau <w@1wt.eu>  

- updated to 1.4.22  

…………略………………  

* Thu Oct 16 2003 Simon Matter <simon.matter@invoca.ch>  

- initial build  

3、获取spec文件方法(三种方法)
3.1 方法1:通过src.rpm包获取
下载&安装相应的src.rpm包
# cd SRPMS/  

# wget http://1wt.eu/tools/haproxy/src/devel/haproxy-1.2.3-1.src.rpm  

# rpm -ivh haproxy-1.2.3-1.src.rpm  

  1:haproxy                ########################################### [100%]  

 这里的“安装”是指把xxx.src.rpm中的tar.gz、patches、xxx.spec等文件分别输出到/usr/src/redhat/的SOURCES、SPECS等子目录中
查看生成的文件
# ls /usr/src/redhat/{SOURCES,SPECS}  

/usr/src/redhat/SOURCES:  

haproxy-1.2.3.tar.gz  

/usr/src/redhat/SPECS:  

haproxy.spec  

找到spec文件,进行备份、修改
# cd /usr/src/redhat/SPECS  

# cd /usr/src/redhat/SPECS  

# cp haproxy.spec haproxy.spec_bak$(date +%F)  

# ls  

haproxy.spec  haproxy.spec_bak2013-01-06  

3.2 方法2:新建spec文件
再目录SPECS下,创建一个新的spec文件,根据spec文件语法规范编写,这个难度较高,适用于自己开发的软件。
3.3 方法3:从源码包中获取已有spec文件 (推荐的方法)
# tar zxf haproxy-1.4.22.tar.gz  

# cd haproxy-1.4.22  

# ll haproxy.spec    

-rw-rw-r-- 1 root root 7442 Aug 14 15:09 haproxy.spec  

#cd haproxy-1.4.22/examples/  

# ls  

haproxy.spec  

将spec放入目录SPECS
# cp haproxy.spec  /usr/src/redhat/SPECS/

备份
# cp haproxy.spec  haproxy.spec.$(date +%F)

本文采用此方法获取spec

4、编辑spec
# pwd /usr/src/redhat/SPECS  

# vim haproxy.spec  

修改前后内容对比(后面为原文件)
[root@study02 SPECS]# diff haproxy.spec haproxy.spec.2013-01-07  

4c4  

< Release: 20130106_hexun_as5  

---

> Release: 1  

36c36  

< %{__make} ARCH=%{_target_cpu} TARGET=linux26  

---

> %{__make} USE_PCRE=1 DEBUG="" ARCH=%{_target_cpu} TARGET=linux26  

5、下载HAProxy源码包
下载源码包并放入SOURCES目录中
# pwd  

/usr/src/redhat/SOURCES  

# wget http://haproxy.1wt.eu/download/1.4/src/haproxy-1.4.22.tar.gz  

# ls haproxy-1.4.22.tar.gz  

6、创建RPM 包
通过rpmbuild命令来解析SPEC文件生成对应的RPM包
6.1 确认rpmbuild 已经安装
# yum install rpm-build -y

6.2 安装依赖包
在build rpm包的系统上安装pcre-devel
# yum -y  install pcre-devel

6.3开始build rpm:
# rpmbuild  -v -ba SPECS/haproxy.spec

6.4 看到如下内容即创建过程,红色内容为build包位置
Executing(%prep): /bin/sh -e /var/tmp/rpm-tmp.44698  

+ umask 022  

+ cd /usr/src/redhat/BUILD  

+ LANG=C  

+ export LANG  

+ unset DISPLAY  

+ cd /usr/src/redhat/BUILD  

+ rm -rf haproxy-1.4.22  

+ /bin/gzip -dc /usr/src/redhat/SOURCES/haproxy-1.4.22.tar.gz  

+ tar -xf -  

+ STATUS=0  

…………略………………  

Wrote: /usr/src/redhat/SRPMS/haproxy-1.4.22-20130106_hexun_as5.src.rpm  

Wrote: /usr/src/redhat/RPMS/x86_64/haproxy-1.4.22-20130106_hexun_as5.x86_64.rpm  

Wrote: /usr/src/redhat/RPMS/x86_64/haproxy-debuginfo-1.4.22-20130106_hexun_as5.x86_64.rpm  

Executing(%clean): /bin/sh -e /var/tmp/rpm-tmp.75459  

+ umask 022  

+ cd /usr/src/redhat/BUILD  

+ cd haproxy-1.4.22  

+ '[' /var/tmp/haproxy-1.4.22-root '!=' / ']'

+ /bin/rm -rf /var/tmp/haproxy-1.4.22-root  

+ exit 0  #注意输出status为0 即创建过程错误

7、检验RPM包
7.1 使用 Mock 和 Koji 去测试 RPM 包
详见 Fedora
新软件维护者指南
7.2 列出RPM软件包内的文件信息
# rpm -qpl   /usr/src/redhat/RPMS/x86_64/haproxy-1.4.22-20130106_hexun_as5.x86_64.rpm  

/etc/haproxy  

/etc/haproxy/haproxy.cfg  

/etc/rc.d/init.d/haproxy  

/usr/sbin/haproxy  

/usr/share/doc/haproxy-1.4.22  

/usr/share/doc/haproxy-1.4.22/CHANGELOG  

/usr/share/doc/haproxy-1.4.22/TODO  

/usr/share/doc/haproxy-1.4.22/acl-content-sw.cfg  

/usr/share/doc/haproxy-1.4.22/architecture.txt  

/usr/share/doc/haproxy-1.4.22/auth.cfg  

/usr/share/doc/haproxy-1.4.22/build.cfg  

/usr/share/doc/haproxy-1.4.22/configuration.txt  

/usr/share/doc/haproxy-1.4.22/content-sw-sample.cfg  

/usr/share/doc/haproxy-1.4.22/cttproxy-src.cfg  

/usr/share/doc/haproxy-1.4.22/examples.cfg  

/usr/share/doc/haproxy-1.4.22/haproxy-en.txt  

/usr/share/doc/haproxy-1.4.22/haproxy-fr.txt  

/usr/share/doc/haproxy-1.4.22/haproxy.cfg  

/usr/share/doc/haproxy-1.4.22/option-http_proxy.cfg  

/usr/share/doc/haproxy-1.4.22/tarpit.cfg  

/usr/share/doc/haproxy-1.4.22/test-section-kw.cfg  

/usr/share/doc/haproxy-1.4.22/url-switching.cfg  

/usr/share/man/man1/haproxy.1.gz

7.3 列出RPM软件包的描述信息
# rpm -qpi   /usr/src/redhat/RPMS/x86_64/haproxy-1.4.22-20130106_hexun_as5.x86_64.rpm  

Name        : haproxy                      Relocations: (not relocatable)  

Version     : 1.4.22                            Vendor: (none)  

Release     : 20130106_hexun_as5            Build Date: Mon 07 Jan 2013 09:36:21 AM CST  

Install Date: (not installed)               Build Host: study02  

Group       : System Environment/Daemons    Source RPM: haproxy-1.4.22-20130106_hexun_as5.src.rpm  

Size        : 1275757                          License: GPL  

Signature   : (none)  

URL         : http://haproxy.1wt.eu/  

Summary     : HA-Proxy is a TCP/HTTP reverse proxy for high availability environments  

Description :  

HA-Proxy is a TCP/HTTP reverse proxy which is particularly suited for high  

availability environments. Indeed, it can:  

- route HTTP requests depending on statically assigned cookies  

- spread the load among several servers while assuring server persistence  

through the use of HTTP cookies  

- switch to backup servers in the event a main one fails  

- accept connections to special ports dedicated to service monitoring  

- stop accepting connections without breaking existing ones  

- add/modify/delete HTTP headers both ways  

- block requests matching a particular pattern  

It needs very little resource. Its event-driven architecture allows it to easily  

handle thousands of simultaneous connections on hundreds of instances without  

risking the system's stability.  

7.4 rpm方式安装验证
[root@study01 tools]# rpm -ivh haproxy-1.4.22-20130106_hexun_as5.x86_64.rpm  

Preparing...                ########################################### [100%]  

  1:haproxy                ########################################### [100%]  

[root@study01 tools]# ls  

haproxy-1.4.22-20130106_hexun_as5.x86_64.rpm  

[root@study01 tools]# ls /etc/haproxy/ #安装目录及主配置文件

haproxy.cfg  

[root@study01 tools]# ll /etc/rc.d/init.d/haproxy  #服务启动文件

-rwxr-xr-x 1 root root 2553 Jan 7 09:36 /etc/rc.d/init.d/haproxy  

[root@study01 tools]# ll /etc/init.d/haproxy  

-rwxr-xr-x 1 root root 2553 Jan 7 09:36 /etc/init.d/haproxy  

[root@study01 tools]# rpm -qf /etc/init.d/haproxy  #查看软件所属软件包

haproxy-1.4.22-20130106_hexun_as5  

至此定制RPM包已经制作完毕,接下来我们就可以把常用的应用软件源码包都制作为rpm包放入yum仓库,以后部署软件就很便捷了。

[align=left][/align]
[align=left][/align]
[align=left][/align]
[align=left]8、将定制的RPM加入yum仓库[/align]
[align=left]所需工具createrepo 、yum-arch[/align]
[align=left]详见很早以前写的yum server搭建文章[/align]
[align=left]《CentOS基于 http服务 搭建yum 源 服务器》http://bbs.linuxtone.org/thread-4439-1-1.html[/align]
[align=left]8.1 在yum server上配置[/align]
[root@hxinstall 5ASU8]# cd /opt/ftp/pub/os/Linux/Centos/x86_64/Centos5.8/  

[root@hxinstall Centos5.8]# ls  

dvd install  

# cd RPMS.hexun/  

# ls  

haproxy-1.4.22-20130106_hexun_as5.x86_64.rpm  

[align=left]8.2 创建repodata 数据库[/align]
[align=left]包含rpm 包的详细信息,依赖关系等[/align]
[root@hxinstall RPMS.hexun]# createrepo /opt/ftp/pub/os/Linux/Centos/x86_64/Centos5.8/RPMS.hexun  

1/1 - haproxy-1.4.22-20130106_hexun_as5.x86_64.rpm                                

Saving Primary metadata  

Saving file lists metadata  

Saving other metadata  

[align=left]8.3 RPM包分析[/align]
[align=left]在目录下产生 heaers 目录[/align]
# yum-arch -l /opt/ftp/pub/os/Linux/Centos/x86_64/Centos5.8/RPMS.hexun  

# ls  

haproxy-1.4.22-20130106_hexun_as5.x86_64.rpm headers repodata  

[align=left]注意:[/align]
[align=left]每添加新的软件包,都需要执行此两个命令使其生效。[/align]
[align=left]8.4 yum 客户端安装定制版HAProxy[/align]
[align=left]8.4.1 配置yum[/align]
[align=left]添加定制软件包yum仓库[/align]
cat << EOF >>  /etc/yum.repos.d/CentOS-Base.repo  

[hexun]  

name= hexun rpm  

baseurl=http://10.0.251.154/pub/os/Linux/Centos/x86_64/Centos5.8/RPMS.hexun  

gpgcheck=0  

EOF  

8.4.2 YUM安装自定制HAProxy 软件包

# yum clean all

# yum  install  haproxy -y  

Loaded plugins: fastestmirror  

Determining fastest mirrors  

……略…………  

hexun                                                       |  951 B     00:00      

hexun/primary                                               | 1.2 kB     00:00      

hexun                                                                          1/1  

Setting up Install Process  

Resolving Dependencies  

--> Running transaction check

---> Package haproxy.x86_64 0:1.4.22-20130106_hexun_as5 set to be updated

………略………  

Running Transaction

 Installing     : haproxy                                                     1/1  

Installed:  #yum已经安装成功

 haproxy.x86_64 0:1.4.22-20130106_hexun_as5

[align=left]8.4.3 卸载定制版软件包[/align]
# yum  remove  haproxy   -y    

Loaded plugins: fastestmirror  

Setting up Remove Process  

Resolving Dependencies  

--> Running transaction check

---> Package haproxy.x86_64 0:1.4.22-20130106_hexun_as5 set to be erased

--> Finished Dependency Resolution

Dependencies Resolved  

===================================================================================  

Package       Arch         Version                          Repository       Size

===================================================================================  

Removing:  

haproxy       x86_64       1.4.22-20130106_hexun_as5        installed       1.2 M  

Transaction Summary  

===================================================================================  

Remove        1 Package(s)  

Reinstall     0 Package(s)  

Downgrade     0 Package(s)  

Downloading Packages:  

Running rpm_check_debug  

Running Transaction Test  

Finished Transaction Test  

Transaction Test Succeeded  

Running Transaction

 Erasing        : haproxy                                                     1/1  

Removed:  #已经成功卸载  

 haproxy.x86_64 0:1.4.22-20130106_hexun_as5  

Complete!  

[align=left]9、制作RPM报错记录[/align]
[align=left]9.1 build包报错找不到源码包[/align]
# rpmbuild -v -ba SPECS/haproxy.spec  

error: File /usr/src/redhat/SOURCES/haproxy-1.4.22.tar.gz: No such file or directory  

[align=left]解决:将对应版本源码包放入对应目录[/align]
# cd /usr/src/redhat/SOURCES/  

[root@study02 SOURCES]# wget http://haproxy.1wt.eu/download/1.4/src/haproxy-1.4.22.tar.gz  

[align=left]9.2 build时报依赖关系错误[/align]
# rpmbuild -v -ba SPECS/haproxy.spec                                

error: Failed build dependencies:  

       pcre-devel is needed by haproxy-1.4.22-20130106_hexun_as5.x86_64  

[align=left]解决:在build rpm包的系统上安装pcre-devel[/align]
# yum -y install pcre-devel      

[align=left]10、制作RPM包涉及到的命令用法[/align]
[align=left]10.1 命令rpmbuild[/align]
[align=left]用法:[/align]
Usage: rpmbuild [ <specfile> | <tarball> | <source package> ]  

[align=left]常用参数:[/align]
[align=left]-bb 只编译二进制rpm包[/align]
[align=left]-bs 只编译源码rpm包(src.rpm)[/align]
[align=left]-ba 同时编译二进制和源码rpm包(src.rpm)[/align]
[align=left]-bp执行到%prep段,解开tar包然后把所有的补丁文件合并而生成一个完整的具最新功能的源文件[/align]
[align=left]10.2 命令rpm[/align]
[align=left]rpm 命令以前的linux版本较常用,但是解决软件包依赖关系就比较麻烦,不如yum便捷。[/align]
[align=left]用法:[/align]
Usage: rpm [OPTION...]  

常用的rpm参数组合:

(1)rpm -qx file_name, x={f,i,l,a,p...}, file_name可以是命令名、动态库名称、配置文件名等等。  

使用此命令的前提:相应的rpm包已经安装。  

rpm -qf file:查询文件file是哪个rpm包中的;rpm -qf `which your_cmd`, rpm -qf `locate file_name`  

rpm -qi rpm_name:查看指定rpm包安装的详细信息;  

rpm -ql installed_rpm_name:列出已经安装的rpm包中包含了哪些文件及他们的安装路径。如rpm -ql iptraf  

用以下选项与 -q 连用来指明要查询哪些软件包的信息。这些选项被称之为“软件包指定选项”:  

-a 查询所有已安装的软件包。  

-f <file> 将查询包含有文件 <file>的软件包。  

-p <packagefile> 查询软件包文件名为 <packagefile>的包。  

有几种方式来指定查询软件包时所显示的信息。 以下选项可通过读取rpm包头部的办法显示rpm包的信息,这样的选项被称作“信息选择选项”:  

-i 显示软件包信息,如描述、发行号、大小、编译日期、安装日期、硬件平台、以及其它一些各类信息。  

-l 列出软件包中包含的文件。(列出已经安装的rpm包中包含了哪些文件及他们的安装路径)  

-s 显示软件包中所有文件的状态。  

-d 列出被标注为文档的文件 (如,man 手册、 info 信息、README,等等) 。  

-c 列出被标注为配置文件的文件。这些文件是需要在安装完毕后加以定制的,如 (sendmail.cf, passwd, inittab, 等) 。  

如果要在执行上述选项的同时,显示文件列表, 可以同时使用 -v 命令行选项,就能得出与 ls -l 格式类似的输出。  

(2)查看未安装的rpm/src.rpm包中包含的文件列表  

- 在本地暂时只能使用(4)中提供的方法;  

- 通过rpmfind.net等网站进行查询;  

(3)rpm -ivh xxx.rpm:重新安装;(和-Uvh相比,建议用-ivh)  

rpm -ivh --relocate /=/tmp/test/ xxx.rpm

(4)rpm2cpio xxx.rpm/xxx.src.rpm:将rpm解压为cpio归档;  

rpm2cpio xxx.rpm/xxx.src.rpm | cpio -idmv (rpm2cpio xxx.rpm | cpio --extract --make-directories)

参数-i(或--extract)表示提取文件; v表示指示执行进程;-d(或--make-directory)表示根据包中文件原来的路径建立目录;m表示保持文件的更新时间。

[align=left]10.3 命令 yum[/align]
[align=left]目前yum命令在安装软件包时很常用,这里不再一一列举用法参数。[/align]
[align=left]常用命令可参考http://bbs.linuxtone.org/thread-4439-1-1.html[/align]
[align=left]11、参考资料[/align]
[align=left]RPM 打包技术与典型 SPEC 文件分析[/align]
[align=left]http://www.ibm.com/developerworks/cn/linux/l-rpm/?S_TACT=105AGX52&S_CMP=tech-51CTO[/align]
[align=left]常用的rpm参数组合[/align]
[align=left]http://www.xdays.info/rpm%E5%8C%85%E5%88%B6%E4%BD%9C.html#file[/align]
[align=left]RPM使用笔记[/align]
[align=left]http://rdc.taobao.com/blog/cs/?p=43#sec-7[/align]
[align=left]How to create an RPM package/zh-cn[/align]
[align=left]https://fedoraproject.org/wiki/How_to_create_an_RPM_package/zh-cn#.E6.96.B0.E5.BB.BA.E4.B8.80.E4.B8.AA.E7.A9.BA.E7.99.BD.E7.9A.84_.spec_.E6.96.87.E4.BB.B6[/align]
[align=left]Fedora 新软件维护者指南[/align]
[align=left]https://fedoraproject.org/wiki/Fedora_%E6%96%B0%E8%BD%AF%E4%BB%B6%E7%BB%B4%E6%8A%A4%E8%80%85%E6%8C%87%E5%8D%97?rd=Fedora%E9%8F%82%E6%9D%BF%EE%9A%9C%E6%B5%A0%E5%89%81%E6%B7%AE%E9%8E%B6%E3%82%88%E2%82%AC%E5%91%AE%E5%AF%9A%E9%8D%97?#.E4.BD.BF.E7.94.A8_Mock_.E5.92.8C_Koji_.E5.8E.BB.E6.B5.8B.E8.AF.95_RPM_.E5.8C.85[/align]
[align=left][/align]
[align=left][/align]
最近看有网友使用EPM(Effing Package Management),方便易用,有空我也学习使用下,先将资料分享给大家,一起学习:
https://github.com/jordansissel/fpm/wiki
本文出自 “Dreamway的运维点滴” 博客,请务必保留此出处http://dreamway.blog.51cto.com/1281816/1110874
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: