中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Linux程序包管理

發布時間:2020-10-14 14:07:40 來源:網絡 閱讀:490 作者:連振英 欄目:數據庫

Linux程序包管理


  • RPM包基礎

  • RPM

  • YUM

  • 編譯安裝


概述

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

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

RPM包

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

源代碼:
    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表示與平臺無關

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

Application-VERSION-ARCH.rpm: 主包
Application-devel-VERSION-ARCH.rpm開發子包
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]
數據庫維護: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: 查詢所有已經安裝過的包	
    -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發行版來說:    #rpm --import /media/cdrom/RPM-GPG-KEY-CentOS-7驗證:
	(1)安裝此組織簽名的程序時,會自動執行驗證
	(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.用私鑰加密特征碼,附加在文件后面,私鑰加密的特征碼就是數字簽名;

使用者:

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

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

[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)不要對內核做升級操作;Linux支持多內核版本并存,因此,直接安裝新版本內核;
(2)如果某原程序包的配置文件安裝后曾被修改過,升級時,新版本的程序提供的
同一個配置文件不會覆蓋原有版本的配置文件,而是把新版本的配置文件重命名后
(FILENAME.rpmnew)后提供;
  1. 數據庫重建| 此功能慎用!

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

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

在其他目錄構建rpm數據庫:

[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

看重建之后的區別

[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命令實現程序管理:

安裝:-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數據庫重建:--initdb, --rebuilddb

YUM

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

yum的主要知識點:

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

yum客戶端的配置文件

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

什么是yum的倉庫?

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

如何指向yum倉庫,這就需要我們來配置/etc/yum.repos.d/*.repo ,重要的一點是,指向yum倉庫的地址一定是 repodata 這個rpm包元數據文件的父目錄,且該配置文件的命名必須要以.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實現rpm的相應功能了。

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

yum-config-manager命令:

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

快速創建網絡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程序包管理

快速創建光盤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配置腳本已經寫好,問題來了,當我們在一個既有CentOS 7, 又有CentOS 6的環境中需要運行yum的repo配置文件時,發現適用于適用于CentOS 7的不適用于CentOS 6,反之亦然,如此,repo配置文件也有了屬于自己的變量:

yum的repo配置文件中可用的變量:
$releasever: 當前OS的發行版的主版本號
$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   # 在本地創建/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>     # 目錄是必選

創建本地yum源:

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

Linux程序包管理

創建配置文件:

[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源就可以認為創建成功了!

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   # 緩存元數據
搜索:yum search string1 [string2] [...]以指定的關鍵字搜索程序包名及summary信息
查看指定包所依賴的capabilities:
    yum deplist package1 [package2] [...]查看yum事務歷史:
    yum history
    yum history info 6
    yum history undo 6  # 執行yum命令的撤銷操作
日志:/var/log/yum.log

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

相關示例:

[root@centos7 ~]#yum makecache   # 緩存元數據
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的常規安裝卸載升級命令用法相似。

源碼編譯

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

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

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

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

實現:通過“包組”提供開發組件
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環境變量中;
編輯文件/etc/profile.d/NAME.shexport PATH=/PATH/TO/BIN:$PATH(2) 導入庫文件路徑
編輯/etc/ld.so.conf.d/NAME.conf添加新的庫文件所在目錄至此文件中
讓系統重新生成緩存:
ldconfig[-v]
(3) 導入頭文件
基于鏈接的方式實現:
ln -sv
(4) 導入幫助手冊
編輯/etc/man.config|man_db.conf文件
添加一個MANPATH
  1. 將二進制程序目錄導入至PATH環境變量中

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程序包管理

現在我們嘗試使用man幫助:

Linux程序包管理

apachectl - Apache HTTP Server Control Interfacestartstop restart

現在嘗試啟動http:

[root@centos7 ~]#apachectl start

查看80端口是否已開啟:

[root@centos7 ~]#netstat -ant

Linux程序包管理

OK,我們來查看一下網頁:

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

Linux程序包管理

Linux程序包管理

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

Linux程序包管理

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

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

止戰

2016.8.26


向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

睢宁县| 舟曲县| 扶风县| 大丰市| 江北区| 高台县| 黔西县| 莆田市| 广平县| 峨眉山市| 红桥区| 河东区| 洪江市| 徐水县| 安乡县| 清水县| 大宁县| 长岛县| 资阳市| 天津市| 山西省| 张家口市| 报价| 富宁县| 西宁市| 沅陵县| 普格县| 扬州市| 昌平区| 宜州市| 清流县| 宁夏| 永清县| 惠州市| 鞍山市| 泸州市| 奉贤区| 湟中县| 冀州市| 平阴县| 六枝特区|