日B视频 亚洲,啪啪啪网站一区二区,91色情精品久久,日日噜狠狠色综合久,超碰人妻少妇97在线,999青青视频,亚洲一区二卡,让本一区二区视频,日韩网站推荐

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內(nèi)不再提示

關于Linux下的crontab,你不知道的那些知識點

Linux愛好者 ? 來源:一口Linux ? 作者:一口Linux ? 2022-12-21 13:57 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

際工作中,crontab出現(xiàn)的問題是多種多樣的,下面就深入介紹下crontab在具體工作中容易出現(xiàn)的問題和解決問題的辦法。

一、crontab能干啥

crond是linux下用來周期性的執(zhí)行某種任務或等待處理某些事件的一個守護進程,與windows下的計劃任務類似,當安裝完成操作系統(tǒng)后,默認會安裝此服務工具,并且會自動啟動crond進程,crond進程每分鐘會定期檢查是否有要執(zhí)行的任務,如果有要執(zhí)行的任務,則自動執(zhí)行該任務。

Linux下的任務調(diào)度分為兩類,系統(tǒng)任務調(diào)度和用戶任務調(diào)度。

  • 系統(tǒng)任務調(diào)度:系統(tǒng)周期性所要執(zhí)行的工作,比如寫緩存數(shù)據(jù)到硬盤、日志清理等。

  • 用戶任務調(diào)度:用戶定期要執(zhí)行的工作,比如用戶數(shù)據(jù)備份、定時郵件提醒等。用戶可以使用 crontab 工具來定制自己的計劃任務。所有用戶定義的crontab 文件都被保存在 /var/spool/cron目錄中。其文件名與用戶名一致。

關于crontab的用途,在企業(yè)實際應用中非常廣泛,常見的有定時數(shù)據(jù)備份、定時系統(tǒng)檢測、定時數(shù)據(jù)收集、定時更新配置、定時生成報表等等。

二、crontab應用實例

1、crontab使用格式

crontab常用的使用格式有如下兩種:

crontab [-u user] [file]
crontab [-u user] [-e|-l|-r |-i]

選項含義如下:

  • -u user:用來設定某個用戶的crontab服務,例如,“-u ixdba”表示設定ixdba用戶的crontab服務,此參數(shù)一般有root用戶來運行。

  • file:file是命令文件的名字,表示將file做為crontab的任務列表文件并載入crontab。如果在命令行中沒有指定這個文件,crontab命令將接受標準輸入(鍵盤)上鍵入的命令,并將它們載入crontab。

  • -e:編輯某個用戶的crontab文件內(nèi)容。如果不指定用戶,則表示編輯當前用戶的crontab文件。

  • -l:顯示某個用戶的crontab文件內(nèi)容,如果不指定用戶,則表示顯示當前用戶的crontab文件內(nèi)容。

  • -r:從/var/spool/cron目錄中刪除某個用戶的crontab文件,如果不指定用戶,則默認刪除當前用戶的crontab文件。

  • -i:在刪除用戶的crontab文件時給確認提示。

2、crontab文件語法

用戶所建立的crontab文件中,每一行都代表一項任務,每行的每個字段代表一項設置,它的格式共分為六個字段,前五段是時間設定段,第六段是要執(zhí)行的命令段,格式如下:

minute hour day month week command

其中:

? minute:表示分鐘,可以是從0到59之間的任何整數(shù)。

? hour:表示小時,可以是從0到23之間的任何整數(shù)。

? day:表示日期,可以是從1到31之間的任何整數(shù)。

? month:表示月份,可以是從1到12之間的任何整數(shù)。

? week:表示星期幾,可以是從0到7之間的任何整數(shù),這里的0或7代表星期日。

? command:要執(zhí)行的命令,可以是系統(tǒng)命令,也可以是自己編寫的腳本文件。

在以上各個字段中,還可以使用以下特殊字符:

? 星號():代表所有可能的值,例如month字段如果是星號,則表示在滿足其它字段的制約條件后每月都執(zhí)行該命令操作。

? 逗號(,):可以用逗號隔開的值指定一個列表范圍,例如,“1,2,5,7,8,9”

? 中杠(-):可以用整數(shù)之間的中杠表示一個整數(shù)范圍,例如“2-6”表示“2,3,4,5,6”

? 正斜線(/):可以用正斜線指定時間的間隔頻率,例如“0-23/2”表示每兩小時執(zhí)行一次。同時正斜線可以和星號一起使用,例如/10,如果用在minute字段,表示每十分鐘執(zhí)行一次。

3、幾個crontab例子

0 /3 /usr/local/apache2/apachectl restart

表示每隔3個小時重啟apache服務一次。

30 3 6 /webdata/bin/backup.sh

表示每周六的3點30分執(zhí)行/webdata/bin/backup.sh腳本的操作。

0 0 1,20 fsck /dev/sdb8

表示每個月的1號和20號檢查/dev/sdb8磁盤設備。

10 5 /5 * echo "">/usr/local/apache2/log/access_log

表示每個月的5號、10號、15號、20號、25號、30號的5點10分執(zhí)行清理apache日志操作。

三、系統(tǒng)級任務調(diào)度/etc/crontab

在/etc目錄下有一個crontab文件,這個就是系統(tǒng)任務調(diào)度的配置文件。

/etc/crontab文件包括下面幾行:

SHELL=/bin/bash
PATH=/sbin:/bin:/usr/sbin:/usr/bin
MAILTO=root
HOME=/
# run-parts
01 * * * * root run-parts /etc/cron.hourly
02 4 * * * root run-parts /etc/cron.daily
22 4 * * 0 root run-parts /etc/cron.weekly
42 4 1 * * root run-parts /etc/cron.monthly

從上面的示例文件可看出,crontab的任務列表主要由兩部分組成:環(huán)境變量配置與定時任務配置??赡艽蠹以诠ぷ髦懈嗍侵挥玫搅巳蝿张渲貌糠?。

前四行是用來配置crond任務運行的環(huán)境變量,第一行SHELL變量指定了系統(tǒng)要使用哪個shell,這里是bash,第二行PATH變量指定了系統(tǒng)執(zhí)行命令的路徑,第三行MAILTO變量指定了crond的任務執(zhí)行信息將通過電子郵件發(fā)送給root用戶,如果MAILTO變量的值為空,則表示不發(fā)送任務執(zhí)行信息給用戶,第四行的HOME變量指定了在執(zhí)行命令或者腳本時使用的主目錄。第六至九行就是crontab執(zhí)行格式的具體寫法。

四、crontab調(diào)試解析神器

通常在使用crontab添加任務時,我們會依靠自己已有知識編寫定時語句。當需要測試語句是否正確時,還需要在服務器上不斷調(diào)試,,這種方式太不高效了。有沒有一款工具,只要我們給出語句,就能告訴具體執(zhí)行時間以及對錯呢?還真有,下面介紹一款老外開發(fā)的crontab在線解析工具。

工具地址:https://crontab.guru

給出這個工具的截圖如下:

1460260a-80e6-11ed-8abf-dac502259ad0.png

好用不好用,你試試就知道。

五、crontab使用的各種坑

1、環(huán)境變量問題

當我們剛使用crontab時,運維老鳥們一般會告知所有命令盡量都使用絕對路徑,以防錯誤。這是為什么?這就和我們下面要談的環(huán)境變量有關了。

首先,獲取shell終端環(huán)境變量,內(nèi)容如下:

[root@SparkWorker1 dylogs]# env
XDG_SESSION_ID=1629
HOSTNAME=SparkWorker1
TERM=linux
SHELL=/bin/bash
HISTSIZE=1000
SSH_CLIENT=172.16.213.132 50080 22
HADOOP_PREFIX=/opt/hadoop/current
CATALINA_BASE=/opt/hadoop/current/share/hadoop/httpfs/tomcat
SSH_TTY=/dev/pts/1
QT_GRAPHICSSYSTEM_CHECKED=1
USER=root
MAIL=/var/spool/mail/root
PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/usr/java/default/bin:/opt/hadoop/current/bin:/opt/hadoop/current/sbin:/root/bin
PWD=/data/dylogs
LANG=zh_CN.UTF-8
HOME=/root

要獲取crontab環(huán)境變量信息,可以設置如下計劃任務:

* * * * * /usr/bin/env > /tmp/env.txt

等待片刻,env.txt輸出內(nèi)容如下:

[root@SparkWorker1 dylogs]# cat /tmp/env.txt
XDG_SESSION_ID=1729
SHELL=/bin/sh
USER=root
PATH=/usr/bin:/bin
PWD=/root
LANG=zh_CN.UTF-8
SHLVL=1
HOME=/root
LOGNAME=root
XDG_RUNTIME_DIR=/run/user/0
_=/usr/bin/env

從上面輸出結(jié)果可知,shell命令行的PATH值為

PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/usr/java/default/bin:/opt/hadoop/current/bin:/opt/hadoop/current/sbin:/root/bin

而crontab中的PATH值為:

PATH=/usr/bin:/bin

對比crontab環(huán)境變量與shell終端環(huán)境變量的輸出,可以發(fā)現(xiàn)兩者的差異很大。大家可能遇到過,在shell命令行執(zhí)行腳本都沒有問題,而放到crontab后卻執(zhí)行異常,或者執(zhí)行失敗,此時,我們就需要考慮是否命令涉及的環(huán)境變量在crontab和shell命令行間存在差異。

例如,我們在crontab中執(zhí)行了如下定時任務:

20 16 * * * php autosave.php

而如果我們的php是安裝在/usr/local/bin/目錄下的話,那么上面這個定時任務由于無法找到php命令,會運行失敗。

那么,知道了環(huán)境變量問題,可能導致計劃任務無法正常執(zhí)行,怎么才能避免這個問題呢,這個交給大家一個終極大招,可以在crontab中加入如下配置,保證你的計劃任務執(zhí)行不會出現(xiàn)環(huán)境變量問題:

* * * * * source /$HOME/.bash_profile && command

這個其實是在執(zhí)行計劃任務命令之前,先加載了用戶環(huán)境變量信息,由此可保證所有環(huán)境變量都可正常加載。

2、定時時間配置誤區(qū)

時間是crontab的核心,稍微配置不當,就會出現(xiàn)問題,先看在整點時間設置時可能出現(xiàn)的錯誤,例如,設定每天2點執(zhí)行一次任務,很多朋友可能這么寫過:

* 2 * * * command

很明顯,這個時間寫法是錯誤的,當我們聽到每天2點執(zhí)行一次某任務時,很多人會把重點放在2點,而忽略了執(zhí)行一次的需求。上面這個定時任務他會在2點開始執(zhí)行,每分鐘執(zhí)行一次,總共執(zhí)行60次。

正確的寫法應該是這樣的:

0 2 * * * command

這個才表示每天2點0分執(zhí)行command對應的任務。

3、特殊符號%問題

%在crontab中是特殊符號,具體含義如下:

第一個%表示標準輸入的開始,其余%表示換行符,看下面兩個例子:

* * * * * cat >> /tmp/cat.txt 2>&1 % stdin out

查看/tmp/cat.txt的內(nèi)容為:

stdin out

再看下面這個例子:

* * * * * cat >> /tmp/cat1.txt 2>&1 % stdin out 1 % stdin out 2 % stdin out 3

查看 /tmp/cat1.txt的內(nèi)容如下:

stdin out 1
stdin out 2
stdin out 3

有輸出內(nèi)容可知,第一個%表示標準輸入的開始,其余%表示換行符。

既然"%"是特殊字符,那么在crontab中使用時,就要特別注意,怎么使用這些特殊字符呢,很明顯,使用轉(zhuǎn)移字符即可,例如:

* * * * * cat >> /tmp/cat2.txt 2>&1 % Special character escape \%.

查看輸出/tmp/cat2.txt 輸出內(nèi)容如下:

Special character escape %.

可以看到,執(zhí)行成功了,并成功避開這個坑了。

4、關于crontab的輸出重定向

在crontab執(zhí)行的計劃任務中,有些任務如果不做輸出重定向,那么原本會輸出到屏幕的信息,會以郵件的形式輸出到某個文件中,例如,執(zhí)行下面這個計劃任務:

* * * * * /bin/date

這個計劃任務是沒有做輸出重定向的,他的主要用途是輸出時間,由于沒有配置輸出重定向,那么這個時間信息默認將以郵件的形式輸出到/var/spool/mail/$USER(這個$USER對應的是系統(tǒng)用戶,這里是root用戶)文件中,大致內(nèi)容如下:

From root@SparkWorker1.localdomain Fri Sep 21 1202 2022
Return-Path: 
X-Original-To: root
Delivered-To: root@SparkWorker1.localdomain
Received: by SparkWorker1.localdomain (Postfix, from userid 0)
id F2745192AE; Fri, 21 Sep 2022 1201 +0800 (CST)
From: "(Cron Daemon)" 
To: root@SparkWorker1.localdomain
Subject: Cron  /bin/date
Content-Type: text/plain; charset=UTF-8
Auto-Submitted: auto-generated
Precedence: bulk
X-Cron-Env: 
X-Cron-Env: 
X-Cron-Env: 
X-Cron-Env: 
X-Cron-Env: 
X-Cron-Env: 
X-Cron-Env: 
X-Cron-Env: 
Message-Id: <20220921045801.F2745192AE@SparkWorker1.localdomain>
Date: Fri, 21 Sep 2022 1201 +0800 (CST)
2022 09 21 星期五 1201 CST

由此可見,輸出內(nèi)容還是很多的,如遇到任務有大量輸出的話,會占用大量磁盤空間,顯然,這個郵件輸出最好關閉,怎么關閉呢,只需設置MAILTO環(huán)境變量為空即可,上面的計劃任務,可做如下修改:

MAILTO=""
* * * * * /bin/date

這樣,就不會發(fā)郵件信息到/var/spool/mail/$USER下了,但是問題并沒有徹底解決,關閉mail功能后,輸出內(nèi)容將繼續(xù)寫入到/var/spool/clientmqueue中,長期下去,可能占滿分區(qū)的inode資源,導致任務無法執(zhí)行。

為了避免此類問題發(fā)生,建議任務都加上輸出重定向,例如,可以在crontab文件中設置如下形式,忽略日志輸出:

0 */3 * * * /usr/local/apache2/apachectl restart >/dev/null 2>&1

其中,“/dev/null 2>&1”表示先將標準輸出重定向到/dev/null,然后將標準錯誤重定向到標準輸出,由于標準輸出已經(jīng)重定向到了/dev/null,因此標準錯誤也會重定向到/dev/null,這樣日志輸出問題就解決了。

5、調(diào)試crontab問題的一般思路

要解決crontab相關異常問題,可按照如下思路進行調(diào)試:

(1)、通過/var/log/cron日志確認任務是否執(zhí)行

(2)、如未執(zhí)行則分析定時語句,是否是環(huán)境變量問題、特殊字符問題、時間配置問題、權(quán)限問題等。

(3)、確認crond服務開啟,如果定時語句也正確,檢查crond服務是否開啟。

Systemd方式(centos7及以上)

[root@SparkWorker1 spool]# systemctl status crond.service

SysVinit方式(centos7以下)

[root@SparkWorker1 spool]# service crond status

(4)確認定時任務中命令是否執(zhí)行成功

這個問題可通過輸出獲取錯誤信息進行調(diào)試,方法就是利用重定向獲取輸出,然后進行分析。舉例如下:

* * * * * python /usr/local/dyserver/dypos.py >> /tmp/dypos.log 2>&1

通過加上“/tmp/dypos.log 2>&1”,就可以很快定位問題,因為這個dypos.py腳本在執(zhí)行的時候會把錯誤信息都輸出到dypos.log 中,接著查看dypos.log文件,問題一目了然:

[root@SparkWorker1 spool]# cat /tmp/dypos.log
/bin/sh: python: 未找到命令
/bin/sh: python: 未找到命令

顯示python命令沒有找到,很明顯的就可以確定是環(huán)境變量的問題。這種方式定位問題非常有效。


審核編輯 :李倩


聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學習之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • Linux
    +關注

    關注

    88

    文章

    11822

    瀏覽量

    219602
  • 服務器
    +關注

    關注

    14

    文章

    10371

    瀏覽量

    91774
  • 操作系統(tǒng)

    關注

    37

    文章

    7443

    瀏覽量

    129644
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    關于車速傳感器磁鐵的一些知識點

    車速傳感器磁鐵在測量車輛速度中扮演著至關重要的角色,通過與霍爾效應傳感器或磁阻傳感器配合使用,利用磁場變化來生成信號,進而反映車速,今天來介紹下車速傳感器磁鐵的幾個關鍵知識點。首先,磁鐵材質(zhì)方面
    的頭像 發(fā)表于 04-29 10:40 ?84次閱讀
    <b class='flag-5'>關于</b>車速傳感器磁鐵的一些<b class='flag-5'>知識點</b>

    示波器小知識點

    示波器的系統(tǒng)帶寬:是指一個逐漸升高頻率的正弦輸入信號顯示幅度下降3dB時的頻率。測試信號一般是方波,而方波信號由基波及奇次諧波組成。如果用示波器去測一個方波,需要注意示波器應從頻率上能夠測量到它
    的頭像 發(fā)表于 04-16 11:04 ?115次閱讀
    示波器小<b class='flag-5'>知識點</b>

    【黑金云課堂筆記】第三期知識點總結(jié)

    ,對 FPGA 免費直播課的熱情也感染到了黑金云課堂的老師們。接下來我們會再接再厲,把每一期直播都做得更扎實 ? 更多精彩課程歡迎關注我們 黑金云課堂全年免費直播課 ,現(xiàn)在讓我們先來回顧一上周的知識點精華—— ? 數(shù)據(jù)類型 常量 進制表示:二進制(b/B)、八進制(o/
    的頭像 發(fā)表于 04-01 16:08 ?210次閱讀
    【黑金云課堂筆記】第三期<b class='flag-5'>知識點</b>總結(jié)

    的EMC瓶頸,不是經(jīng)驗不夠,是體系不全

    EMC的EMC瓶頸,不是經(jīng)驗不夠,是體系不全現(xiàn)在的狀態(tài),是不是這樣?產(chǎn)品送測前,心里完全沒底,不知道哪一項會掛傳導發(fā)射超標,換了十幾種電容電感,還是壓不下去靜電打幾下,系統(tǒng)重啟,
    的頭像 發(fā)表于 03-10 16:41 ?487次閱讀
    <b class='flag-5'>你</b>的EMC瓶頸,不是經(jīng)驗不夠,是體系不全

    組合導航不知道怎么選,看這里

    單一導航難適配復雜作業(yè)?MEMS組合導航來幫你,通過融合衛(wèi)星定位與慣性測量技術(shù),以“1+1>2”優(yōu)勢破解全行業(yè)導航難題。 我司組合導航提供三種方案可選,從01到03到05,搭載從導航級到戰(zhàn)術(shù)級到消費級MEMS陀螺儀與加速度計,通過微機電技術(shù)集成在毫米芯片上,搭載衛(wèi)星模塊以及其他器件,尺寸僅有65mm*70mm*45.5mm,以下是三種方案詳細介紹: 超高精度方案—ER-GNSS/MINS-01 產(chǎn)品定位 一款擁有測繪級超高精度的組合導航,是市面上采用MEMS技術(shù)組合導航系統(tǒng)中
    的頭像 發(fā)表于 01-08 15:47 ?390次閱讀

    移植蜂鳥需要在Linux環(huán)境嗎?

    《手把手教你設計CPU》書上運行Verilog仿真測試那章說為了重現(xiàn)仿真環(huán)境,最好在Linux環(huán)境不知道移植蜂鳥是否需要在Linux環(huán)境
    發(fā)表于 11-10 07:42

    【項目實戰(zhàn)】基于WS63的鴻蒙星閃紅外遙控車(循跡、超聲波避障、遠程控制、星閃/紅外遙控)有教程代碼

    很多物聯(lián)網(wǎng)學習者總覺得“學了用不上”:單獨會接傳感器、懂通信協(xié)議,可一到“多模塊協(xié)同”就慌了——不知道怎么讓超聲波模塊的測距數(shù)據(jù)通過星閃傳出去,也沒試過用小程序遠程控制小車避障。而這臺基于WS63
    的頭像 發(fā)表于 09-10 16:01 ?1272次閱讀
    【項目實戰(zhàn)】基于WS63的鴻蒙星閃紅外遙控車(循跡、超聲波避障、遠程控制、星閃/紅外遙控)有教程代碼

    Crontab定時任務完全指南

    在凌晨3,當大多數(shù)人還在熟睡時,一位運維工程師的手機突然響起——線上數(shù)據(jù)庫備份失敗了。他匆忙起床,打開電腦,手動執(zhí)行備份腳本,整個過程耗時2小時。這樣的場景,在我剛?cè)胄袝r經(jīng)常遇到。直到我真正掌握了crontab定時任務,才徹底擺脫了"人肉運維"的窘境。
    的頭像 發(fā)表于 09-05 10:03 ?1037次閱讀

    Linux系統(tǒng)安裝技巧與分區(qū)策略

    還記得第一次裝Linux系統(tǒng)時的忐忑嗎?面對fdisk命令行界面,不知道該如何下手。經(jīng)歷過無數(shù)次系統(tǒng)重裝、數(shù)據(jù)丟失的痛苦后,我總結(jié)出了這套"零事故"的分區(qū)方案。
    的頭像 發(fā)表于 08-06 17:51 ?1300次閱讀

    Linux權(quán)限體系解析

    真的了解Linux權(quán)限嗎?大多數(shù)人只知道rwx,但Linux的權(quán)限體系遠比你想象的復雜和強大。今天我們深入探討Linux的12位權(quán)限體系,
    的頭像 發(fā)表于 07-23 16:57 ?1100次閱讀

    【「Yocto項目實戰(zhàn)教程:高效定制嵌入式Linux系統(tǒng)」閱讀體驗】01初讀體驗

    習過yocto,導致一看目錄時,基本上沒看明白脈絡,僅僅知道的是,第一二章內(nèi)容屬于背景知識,從第三章開始,就逐步切換到y(tǒng)octo知識點的講解了,到第8章開始將樹莓派鏡像定制,8到9章都是以樹莓派為例
    發(fā)表于 06-30 21:49

    關于OFDM 不知道那些事?#OFDM #5G技術(shù) #通信技術(shù)

    通信技術(shù)
    安泰儀器維修
    發(fā)布于 :2025年06月24日 18:31:22

    編譯錯誤: error: unrecognizable insn,不知道原因,請教!

    用start_gui.exe生成的代碼,再用SEGGER Embedded打開,編譯有錯,不知道是什么原因,請教各位大佬?
    發(fā)表于 06-23 14:45

    關于SFP連接器必須了解的那些知識

    關于SFP連接器必須了解的那些知識 一、SFP光籠子的作用及材料組成 1.光籠子的概念與作用 ① 光籠子是什么? SFP Cage(Small Form-factor Pluggab
    的頭像 發(fā)表于 06-17 09:42 ?1287次閱讀
    <b class='flag-5'>關于</b>SFP連接器<b class='flag-5'>你</b>必須了解的<b class='flag-5'>那些</b><b class='flag-5'>知識</b>

    C51單片機及C語言知識點必備秘籍

    單片機關鍵知識點一覽: 系列一 1:單片機簡敘 2:單片機引腳介紹 3:單片機存儲器結(jié)構(gòu) 4:第一個單片機小程序 5:單片機延時程序分析 6:單片機并行口結(jié)構(gòu) 7:單片機的特殊
    發(fā)表于 05-15 14:00
    花莲市| 垣曲县| 象山县| 江山市| 简阳市| 穆棱市| 云霄县| 东山县| 枣强县| 桐柏县| 营口市| 万盛区| 南平市| 铜鼓县| 阿瓦提县| 清徐县| 苏尼特右旗| 云南省| 孟州市| 哈尔滨市| 余干县| 通化县| 肇庆市| 通渭县| 高要市| 大理市| 浮梁县| 平罗县| 花莲市| 华容县| 金塔县| 和田市| 丹阳市| 江安县| 隆尧县| 长宁区| 海兴县| 万安县| 五常市| 马龙县| 齐河县|