中文字幕日韩精品一区二区免费_精品一区二区三区国产精品无卡在_国精品无码专区一区二区三区_国产αv三级中文在线

Linux程序包管理-創(chuàng)新互聯(lián)

Linux程序包管理



概述

Linux上的程序包管理,是我們的必備技能,本文將從三個視角:rpm、yum、源碼編譯來淺析Linux的程序包管理。首先,我們來看下本文的主要內(nèi)容:

- 程序包的命名- RPM: 程序包管理器    安裝、卸載、升級、查詢、校驗、數(shù)據(jù)庫維護
    
- YUM: RPM的前端程序    yum的配置文件
    yum的常規(guī)操作:升級、檢查、卸載、查看、包組管理
    使用光盤當作本地yum倉庫
    yum的命令行選項及repo配置文件中的可用變量
    
- 編譯安裝    編譯安裝三步驟
    編譯安裝后的相關配置

RPM包

在了解RPM之前,我們需要了解下關于rpm包的基本知識,通常,一個二進制應用程序的組成部分有:二進制文件、庫文件、配置文件、幫助文件,而源代碼與rpm包都有各自的命名規(guī)則:

源代碼:
    name-VERSION.tar.gz|bz2|xz
    其中,VERSION: major.minor.release
    
rpm包:
    name-VERSION-release.arch.rpm
    其中,VERSION: major.minor.release
         release:release.OS
    如:ash-4.2.46-19.el7.x86_64.rpm
    
    另外,noarch表示與平臺無關

而包與包之間,是存在依賴關系的,甚至循環(huán)依賴,由此才有也RPM與YUM,以下為包的主要分類:

Application-VERSION-ARCH.rpm: 主包
Application-devel-VERSION-ARCH.rpm開發(fā)子包
Application-utils-VERSION-ARHC.rpm其它子包
Application-libs-VERSION-ARHC.rpm其它子包

對于庫文件,有以下兩個常用命令及相關配置文件

ldd: 查看二進制程序所依賴的庫文件
ldconifg: 管理及查看本機裝載的庫文件
配置文件:/etc/ld.so.conf, /etc/ld.so.conf.d/*.conf
緩存文件:/etc/ld.so.cache

下面是一個常見的rpm包:

Linux程序包管理


RPM

rpm - RPM Package Manager

RPM就是一個包管理器,對rpm的主要操作有:

安裝:rpm {-i|--install} [install-options] PACKAGE_FILE ...
卸載:rpm {-e|--erase} [--allmatches] [--nodeps] [--noscripts]
升級:rpm {-U|--upgrade} [install-options] PACKAGE_FILE ...      
     rpm {-F|--freshen} [install-options] PACKAGE_FILE ...
查詢:rpm {-q|--query} [select-options] [query-options]
校驗:rpm {-V|--verify} [select-options] [verify-options]
數(shù)據(jù)庫維護:rpm {--initdb|--rebuilddb}
            /var/lib/rpm

使用示例

  1. 安裝一個rpm包:

[root@centos7 ~]#rpm -ivh tree-1.6.0-10.el7.x86_64.rpm

Linux程序包管理

[install-options]
	-h: hash marks輸出進度條;每個#表示2%的進度;	
	--test: 測試安裝,檢查并報告依賴關系及沖突消息等;	
	--nodeps: 忽略依賴關系,不建議	
	--replacepkgs: 重新安裝,注意不會替換配置文件	
	--nosignature: 不檢查包簽名信息,不檢查來源合法性	
	--nodigest: 不檢查包完整性信息
  1. 卸載一個rpm包:

[root@centos7 ~]#rpm -e tree
[erase-options]
--almatches: 卸載所有匹配指定名稱的程序包的各版本:
--nodeps: 忽略依賴關系 
--test;測試卸載,dry run模式
  1. 查詢一個rpm包:

[root@centos7 ~]#rpm -qi tree

Linux程序包管理

[root@centos7 ~]#rpm -ql tree

Linux程序包管理

[query-options]
    -a,--all: 查詢所有已經(jīng)安裝過的包	
    -f FILE: 查詢指定的文件由哪個程序包安裝生成;	
    --chargelog: 查詢rpm包的changlog; 
    -l,--list: 程序包安裝生成的所有文件列表;	
    -i,--info: 程序包相關的信息,版本號,大小,所屬的包組等	
    -c,--configfiles: 查詢指定的程序提供的配置文件	
    -d,--docfiles: 查詢指定的程序包提供的文檔 
    --provides: 列出指定的程序包提供的所有CAPABILITY	
    -R,--requires: 查詢指定的程序包的依賴關系 
    --scripts: 查看程序包自帶的腳本片斷
  1. 校驗一個rpm包:

[root@centos7 ~]#rpm -V tree 
[root@centos7 ~]#echo $?
0
[root@centos7 ~]#
公鑰如何得到:
   	在光盤中:RPM-GPG-KEY-CentOS-7
   	或者在此路徑下:ls /etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-7
   	獲取并導入信任的包制作者的密鑰:
   	
對于CentOS發(fā)行版來說:    #rpm --import /media/cdrom/RPM-GPG-KEY-CentOS-7驗證:
	(1)安裝此組織簽名的程序時,會自動執(zhí)行驗證
	(2)手動驗證:rpm -K PACKAGE_FILE
[root@centos7 ~]#rpm -K tree-1.6.0-10.el7.x86_64.rpm 
tree-1.6.0-10.el7.x86_64.rpm: rsa sha1 (md5) pgp md5 OK
[root@centos7 ~]#

關于rpm包制作與使用時的加密解密問題:

制作者:

1.使用單向加密算法去提取這個包的特征碼,特征碼是定長的;

2.用私鑰加密特征碼,附加在文件后面,私鑰加密的特征碼就是數(shù)字簽名;

使用者:

1.拿到制作者的公鑰,去解密特征碼,如果能解密則表明該rpm包的確為相應的制作者,這便是來源合法性驗證

2.用同樣的單向加密算法對包作計算,計算得到一個特征碼,然后拿特征碼與解密數(shù)字簽名的特征碼作比對,如果二者一樣,則驗證了其完整性。

[root@centos7 ~]#rpm -ql tree 
/usr/bin/tree
/usr/share/doc/tree-1.6.0
/usr/share/doc/tree-1.6.0/LICENSE
/usr/share/doc/tree-1.6.0/README
/usr/share/man/man1/tree.1.gz

[root@centos7 ~]#echo >> /usr/bin/tree   # 給/usr/bin/tree里面追加空格
[root@centos7 ~]#rpm -V tree # 驗證安裝完之后包文件有無變動
S.5....T.    /usr/bin/tree    # 大小,MD5,時間戳已變

[root@centos7 ~]#rpm -K tree-1.6.0-10.el7.x86_64.rpm # 驗證來源合法性與包的完整性
tree-1.6.0-10.el7.x86_64.rpm: rsa sha1 (md5) pgp md5 OK
[root@centos7 ~]#
校驗:
   S file Size differs
   M Mode differs (includes permissions and file type)   
   5 digest (formerly MD5 sum) differs
   D Device major/minor number mismatch
   L readLink(2) path mismatch
   U User ownership differs
   G Group ownership differs
   T mTime differs
   P caPabilities differ
  1. 升級rpm包:

rpm -Uvh PACKAGE_FILE...
rpm -Fvh PACKAGE_FILE...

-U:升級或安裝-F:升級    --oldpackage: 降級;--force: 強制升級;    
注意:
(1)不要對內(nèi)核做升級操作;Linux支持多內(nèi)核版本并存,因此,直接安裝新版本內(nèi)核;
(2)如果某原程序包的配置文件安裝后曾被修改過,升級時,新版本的程序提供的
同一個配置文件不會覆蓋原有版本的配置文件,而是把新版本的配置文件重命名后
(FILENAME.rpmnew)后提供;
  1. 數(shù)據(jù)庫重建| 此功能慎用!

rpm管理器數(shù)據(jù)庫路徑:/var/lib/rpm/,相關的查詢操作,通過此處的數(shù)據(jù)庫進行;

rpm {--initdb|--rebuilddb}	
--initdb: 初始化數(shù)據(jù)庫,當前無任何數(shù)據(jù)庫可初始化創(chuàng)建一個新的;當前有時不執(zhí)行任何操作;	
--rebuilddb: 重建,無論當前存在與否,直接重新創(chuàng)建數(shù)據(jù)庫

在其他目錄構建rpm數(shù)據(jù)庫:

[root@centos7 ~]#rpm --initdb --dbpath=/tmp/rpm
[root@centos7 ~]#ls /tmp/rpm
/Basenames     __db.003    Name          Requirename
Conflictname  Dirnames    Obsoletename  Sha1header
__db.001      Group       Packages      Sigmd5
__db.002      Installtid  Providename   Triggername

看重建之后的區(qū)別

[root@centos7 ~]#rpm --rebuilddb --dbpath=/tmp/rpm
[root@centos7 ~]#ls /tmp/rpm/                     
Basenames     Dirnames  Installtid  Obsoletename  Providename  Sha1header  Triggername
Conflictname  Group     Name        Packages      Requirename  Sigmd5
[root@centos7 ~]#

rpm命令小結:

rpm命令實現(xiàn)程序管理:

安裝:-ivh, --nodeps, --replacepkgs
卸載:-e, --nodeps
升級:-Uvh, -Fvh, --nodeps, --oldpackge
查詢:-q, -qa, -qf, -qi, -qd, -qc, 
	-q --scripts, -q --chagelog, 
	-q --provides,-q --requires
校驗:-V

導入GPG密鑰:
--import, -K(檢驗來源合法性與包完整性)
--nodeigest(校驗時不檢查完整性)
--nosignature(校驗時不檢查來源合法性)包來源合法性驗正及完整性驗正:
完整性驗正:SHA256
來源合法性驗正:RSA

查詢公鑰:0數(shù)據(jù)庫重建:--initdb, --rebuilddb

YUM

rpm給我們的包管理帶來的便利,但在安裝包時,卻無法自動解決包之間的依賴關系,比如你要安裝一個包,它可能會提示你此包依賴A包,此時就需要再安裝A包了,但在安裝A包時又提示你安裝B包與C包,此時你又不得不再安裝B包與C包,最后再回頭來安裝你想要安裝的包。如此反復,對于一個高效率工作的人來說,簡直苦不堪言??;由此,yum成華麗現(xiàn)身了,yum就是rpm的一個前面工具,其主要的優(yōu)勢是可以自動地解決包與包之間的依賴關系,另外,yum還能一次性安裝一個包組;由可可見,yum是基于rpm的,二者是一個相輔相成的關系。

yum的主要知識點:

yum客戶端的配置文件及變量
使用光盤當作本地yum倉庫
與rpm相近功能的實現(xiàn) 
yum的包組管理功能

yum客戶端的配置文件

/etc/yum.conf:為所有倉庫提供公共配置
/etc/yum.repos.d/*.repo:為倉庫的指向提供配置

什么是yum的倉庫?

我們用rpm安裝rpm包時,rpm包的來源于光盤,在光盤的Packets目錄里面有少量的rpm包;那么,對于yum而言,它也需要指向一個“倉庫”的東西,不然“巧婦難為無米之炊”啊,而這個“倉庫”,既可以是本地的,也可以是網(wǎng)絡上的。

如何指向yum倉庫,這就需要我們來配置/etc/yum.repos.d/*.repo ,重要的一點是,指向yum倉庫的地址一定是 repodata 這個rpm包元數(shù)據(jù)文件的父目錄,且該配置文件的命名必須要以.repo為擴展名,否則出錯!指向yum倉庫的配置文件的定義如下:

[repositoryID]
name=Some name for this repository
baseurl=url://path/to/repository/enabled={1|0}
gpgcheck={1|0}
gpgkey=URL
enablegroups={1|0}
failovermethod={roundrobin|priority}
默認為:roundrobin,意為隨機挑選;
cost= 默認為1000

參考示例:

  1 [base]     # 遠程yum源
  2 name=CentOS 7
  3 baseurl=http://10.1.0.1/cobbler/ks_mirror/7/    # repodata 的父目錄
  4 gpgcheck=1          # 開啟完整性與來源合法性,0則表示關閉
  5 gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-7
  6 enabled=0   # 啟用此yum源,0表示禁用
  7 
  8 [base_local]    # 本地光盤yum源
  9 name=Mirros-CentOS 7
 10 baseurl=file:///media/cdrom   # 光盤的掛載點
 11 gpgcheck=1
 12 gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-7
 13 ecabled=1

Linux程序包管理

顯示倉庫列表

[root@centos7 /etc/yum.repos.d]#yum repolist

Linux程序包管理

此時我們就可以利用yum實現(xiàn)rpm的相應功能了。

當然,天下武功,唯快不破,對于創(chuàng)建yum倉庫,我們還有“快招”!

yum-config-manager命令:

yum-config-manager常用參數(shù):
    --add-repo="repodata的父目錄或光盤的掛載點”    
    --disable "倉庫名“  禁用倉庫    
    --enable "倉庫名”   啟用倉庫

快速創(chuàng)建網(wǎng)絡yum倉庫:

[root@centos7 ~]#yum-config-manager --add-repo=
 Loaded plugins: fastestmirror, langpacks
adding repo from: 

[10.1.0.1_cobbler_ks_mirror_7_]
name=added from: 
baseurl=
enabled=1
[root@centos7 ~]#

Linux程序包管理

快速創(chuàng)建光盤yum倉庫:

[root@centos7 ~]#yum-config-manager --add-repo=
 Loaded plugins: fastestmirror, langpacks
adding repo from: 

 [media_cdrom_]
name=added from: 
baseurl=
enabled=1
[root@centos7 ~]#

Linux程序包管理

禁用base倉庫:

[root@centos7 ~]#yum-config-manager --disable base

Linux程序包管理

該命令實際上是修改了.repo文件,重啟之后依然有效。

Linux程序包管理

開啟base倉庫:

[root@centos7 ~]#yum-config-manager --enable base

Linux程序包管理

禁用所有yum倉庫:

[root@centos7 ~]#yum-config-manager --disable *

開啟所有yum倉庫:

[root@centos7 ~]#yum-config-manager --enable *

另外,yum的repo配置腳本已經(jīng)寫好,問題來了,當我們在一個既有CentOS 7, 又有CentOS 6的環(huán)境中需要運行yum的repo配置文件時,發(fā)現(xiàn)適用于適用于CentOS 7的不適用于CentOS 6,反之亦然,如此,repo配置文件也有了屬于自己的變量:

yum的repo配置文件中可用的變量:
$releasever: 當前OS的發(fā)行版的主版本號
$arch: 平臺,i386,i486,i586,x86_64等
$basearch:基礎平臺;i386
$YUM0-$YUM9:自定義變量

實例:
http://server/centos/$releasever/$basearch/
http://server/centos/7/x86_64
http://server/centos/6/i384

制作本地yum源

我們除了用光盤當作本地yum源外,還可以利用第三方的rpm包來個性化地制作我們所無需要的本地yum源。首先,我們要從一個站點去下載所需的rpm包,然后在下載的rpm包的所在目錄下利用createrepo這個命令就可以制作本地yum源了。

登錄ftp服務器下載所需rpm包:

[root@centos7 ~]#lftp 10.1.0.1lftp 10.1.0.1:~> cd pub   
lftp 10.1.0.1:/pub/Sources/7.x86_64> !mkdir /testdir/zsh   # 在本地創(chuàng)建/testdir/zsh目錄,格式為! COMMAND
lftp 10.1.0.1:/pub/Sources/7.x86_64> lcd /testdir/zsh  # lcd進相應的目錄
lcd ok, local cwd=/testdir/zsh
lftp 10.1.0.1:/pub/Sources/7.x86_64> lpwd   # 查看是否成功進入相應的目錄/testdir/zsh
lftp 10.1.0.1:/pub/Sources/7.x86_64> mget zsh-5.0.2-7.el7_1.2.x86_64.rpm  # 下載rpm包,引自作為測試僅下載一個
2489616 bytes transferred                                    
lftp 10.1.0.1:/pub/Sources/7.x86_64> bye
[root@centos7 ~]#cd /testdir/zsh 
[root@centos7 /testdir/zsh]#ls  
zsh-5.0.2-7.el7_1.2.x86_64.rpm
[root@centos7 /testdir/zsh]#

關于createrepo命令:

createrepo [options] <directory>     # 目錄是必選

創(chuàng)建本地yum源:

[root@centos7 /testdir/zsh]#createrepo .  # 在當前目錄下創(chuàng)建本地yum源

Linux程序包管理

創(chuàng)建配置文件:

[root@centos7 /testdir/zsh]#yum-config-manager --add-repo=
 Loaded plugins: fastestmirror, langpacks
adding repo from: 
[testdir_zsh]
name=added from: 
baseurl=
enabled=1
[root@centos7 /testdir/zsh]#

查看:

Linux程序包管理

驗證:安裝zsh

[root@centos7 /testdir/zsh]#yum -y install zsh

Linux程序包管理

Linux程序包管理

此時,我們的本地yum源就可以認為創(chuàng)建成功了!

yum常見命令行

顯示倉庫列表:yum repolist [all|enabled|disabled]
顯示程序包:yum list {available|installed|updates}
安裝程序包:yum install package1 [package2] [...]
            yum reinstall package1 [package2] [...] (重新安裝)
升級程序包:yum update [package1] [package2] [...]
            yum downgrade package1 [package2] [...] (降級)
檢查可用升級:yum check-update
卸載程序包:yum remove | erase package1 [package2] [...]
查看程序包information:yum info [...]
查看指定的特性(可以是某文件)是由哪個程序包所提供:
    yum provides | whatprovidesfeature1 [feature2] [...]清理本地緩存:
    yum clean [ packages | metadata | expire-cache | rpmdb| plugins | all ]構建緩存:
    yum makecache   # 緩存元數(shù)據(jù)
搜索:yum search string1 [string2] [...]以指定的關鍵字搜索程序包名及summary信息
查看指定包所依賴的capabilities:
    yum deplist package1 [package2] [...]查看yum事務歷史:
    yum history
    yum history info 6
    yum history undo 6  # 執(zhí)行yum命令的撤銷操作
日志:/var/log/yum.log

--nogpgcheck:禁止進行gpgcheck
-y: 自動回答為“yes”
-q:靜默模式
--disablerepo=repoidglob:臨時禁用此處指定的repo
--enablerepo=repoidglob:臨時啟用此處指定的repo
--noplugins:禁用所有插件

相關示例:

[root@centos7 ~]#yum makecache   # 緩存元數(shù)據(jù)
Loaded plugins: fastestmirror, langpacks
testdir_zsh                                                                    | 2.9 kB  00:00:00     
(1/2): testdir_zsh/other_db                                                    | 1.5 kB  00:00:00     
(2/2): testdir_zsh/filelists_db                                                | 5.7 kB  00:00:00     
Loading mirror speeds from cached hostfile
Metadata Cache Created
[root@centos7 ~]#
[root@centos7 ~]#yum history

Linux程序包管理

[root@centos7 ~]#yum check-update  # 檢查可用升級
[root@centos7 ~]#yum -y update zsh

Linux程序包管理

[root@centos7 ~]#yum deplist zsh  查看指定包所依賴的能力capabilities

Linux程序包管理

[root@centos7 ~]#yum provides zsh   # 查看指定的包的特性由哪個程序提供

Linux程序包管理

yum的包組管理功能

yum groupinstall group1 [group2] [...]
yum groupupdate group1 [group2] [...]
yum grouplist [hidden] [groupwildcard] [...]
yum groupremove group1 [group2] [...]
yum groupinfo group1 [...]

包與包組的關系,在其結構關系上,類似于用戶與用戶組的概念,都是為了方便管理。yum的包組管理命令與yum的常規(guī)安裝卸載升級命令用法相似。

源碼編譯

有了rpm與yum,有時也不能完全滿足我們的需求,比如我我們要升級一個程序,但這個程序沒有相應的rpm包,或者其rpm包版本過舊,而我們我們只有源碼包,此時我們就需要編譯安裝程序了;另外,yum安裝時是自動解決依賴關系,有可能安裝了我們好些不需要的東西,而我們不想安裝沒必要的東西,此時,我們也要考慮編譯安裝。編譯安裝有三大步驟,但有時我們也需要具體的軟件具體對待,在編譯前需要閱讀其安裝信息。

C代碼編譯安裝三步驟:
1、./configure:
(1) 通過選項傳遞參數(shù),指定啟用特性、安裝路徑等;執(zhí)行時會參考用戶的指定以及makefile.in文件生成makefile
(2) 檢查依賴到的外部環(huán)境,如依賴的軟件包
2、make:根據(jù)makefile文件,構建應用程序
3、make install:復制文件到相應路徑

開發(fā)工具:
autoconf: 生成configure腳本
automake:生成Makefile.in
注意:安裝前查看INSTALL,README

在編譯前,我們需要準備好開發(fā)環(huán)境與開發(fā)工具,開發(fā)環(huán)境包括:開發(fā)庫,頭文件,glibc, 標準庫;開發(fā)工具包括:make, gcc等;這些開發(fā)組件往往通過“包組”提供,所以我們只需安裝相應的包組就可以了。

實現(xiàn):通過“包組”提供開發(fā)組件
CentOS 6:
Development Tools
Server Platform Development
CentOS 7:
Development Tools
Development and Creative Workstation

在安裝時,./configure --help 可獲取其支持的安裝選項,同時,安裝路徑與配置文件的位置都是可以手工指定的,軟件的可選特性當選擇性的禁用,依賴的包當然也是可禁用的。這就是個性化的編譯安裝:

安裝路徑設定:
--prefix=/PATH: 指定默認安裝位置,默認為/usr/local/
--sysconfdir=/PATH:配置文件安裝位置
System types:支持交叉編譯

Optional Features: 可選特性
--disable-FEATURE
--enable-FEATURE[=ARG]

Optional Packages: 可選包,
--with-PACKAGE[=ARG],依賴包
--without-PACKAGE,禁用依賴關系

下面以安裝http來簡要說明編譯安裝的大致過程:

  1. 下載 httpd-2.2.29.tar.bz2并解壓,進入解壓后的目錄

[root@centos7 ~/httpd-2.2.29]#./configure --prefix=/usr/local/http2 --sysconfdir=/etc/bin/http2

Linux程序包管理

Linux程序包管理

  1. make

[root@centos7 ~/httpd-2.2.29]#make
  1. make install

[root@centos7 ~/httpd-2.2.29]#make install

此時,我們可進入安裝目錄看下:

Linux程序包管理

至此,我們的安裝過程就結束了,要想更加高效地使用該軟件的功能,我們還有安裝后的配置需要“善后”:

安裝后的配置:
(1) 二進制程序目錄導入至PATH環(huán)境變量中;
編輯文件/etc/profile.d/NAME.shexport PATH=/PATH/TO/BIN:$PATH(2) 導入庫文件路徑
編輯/etc/ld.so.conf.d/NAME.conf添加新的庫文件所在目錄至此文件中
讓系統(tǒng)重新生成緩存:
ldconfig[-v]
(3) 導入頭文件
基于鏈接的方式實現(xiàn):
ln -sv
(4) 導入幫助手冊
編輯/etc/man.config|man_db.conf文件
添加一個MANPATH
  1. 將二進制程序目錄導入至PATH環(huán)境變量中

vim http2.sh

export PATH=$PATH:/usr/local/http2
  1. 導入庫文件路徑

vim http2.conf

/usr/local/http2/lib          

[root@centos7 ~]#ldconfig   # 重新生成緩存
[root@centos7 ~]#
  1. 導入頭文件

[root@centos7 /usr/local/http2/include]#ln -sv /usr/local/http2/include /usr/include/http2.h

Linux程序包管理

  1. 導入幫助手冊

Linux程序包管理

現(xiàn)在我們嘗試使用man幫助:

Linux程序包管理

apachectl - Apache HTTP Server Control Interfacestartstop restart

現(xiàn)在嘗試啟動http:

[root@centos7 ~]#apachectl start

查看80端口是否已開啟:

[root@centos7 ~]#netstat -ant

Linux程序包管理

OK,我們來查看一下網(wǎng)頁:

[root@centos7 ~]#links    # 此命令沒有就直接yum安裝

Linux程序包管理

Linux程序包管理

瀏覽器再次查看(此步驟沒必要)

Linux程序包管理

至此,源碼編譯安裝的試驗就結束了!

我們在本文中主要介紹了rpm的常規(guī)命令操作,yum的配置文件及創(chuàng)建網(wǎng)絡yum源、使用光盤當作yum源、創(chuàng)建本地yum源及其常規(guī)操作,最后簡要介紹了下源碼編譯安裝的三步驟,其實make與make install是可以一起執(zhí)行的,即make & make install. 這就是我們程序包管理的主要內(nèi)容了!

止戰(zhàn)

2016.8.26

另外有需要云服務器可以了解下創(chuàng)新互聯(lián)cdcxhl.cn,海內(nèi)外云服務器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務器、裸金屬服務器、高防服務器、香港服務器、美國服務器、虛擬主機、免備案服務器”等云主機租用服務以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應用場景需求。

網(wǎng)站題目:Linux程序包管理-創(chuàng)新互聯(lián)
文章地址:http://www.rwnh.cn/article20/ccjoco.html

成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站排名、標簽優(yōu)化、響應式網(wǎng)站、網(wǎng)站營銷微信公眾號、定制網(wǎng)站

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉載內(nèi)容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)

成都網(wǎng)站建設公司
林周县| 左权县| 工布江达县| 庐江县| 隆尧县| 纳雍县| 南郑县| 贵州省| 京山县| 防城港市| 榕江县| 霍林郭勒市| 福建省| 新和县| 襄垣县| 楚雄市| 丽江市| 浏阳市| 定陶县| 万源市| 陕西省| 竹北市| 凉城县| 福贡县| 贵定县| 景东| 抚顺县| 德令哈市| 漠河县| 金溪县| 扎囊县| 永清县| 黑龙江省| 樟树市| 郎溪县| 墨脱县| 黑山县| 定结县| 金沙县| 铁力市| 峨眉山市|