




版權(quán)說(shuō)明:本文檔由用戶(hù)提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
第python結(jié)合shell自動(dòng)創(chuàng)建kafka的連接器實(shí)戰(zhàn)教程目錄環(huán)境安裝連接oracle的python包獲取oracle表信息去掉多余部分shell腳本處理表信息文件增強(qiáng)版處理表信息腳本
環(huán)境
cat/etc/redhat-release
CentOSLinuxrelease7.5.1804(Core)
[root@localhost~]#uname-a
Linuxlocalhost.localdomain3.10.0-862.el7.x86_64#1SMPFriApr2016:44:24UTC2025x86_64x86_64x86_64GNU/Linux
python-V
Python2.7.5
安裝連接oracle的python包
pipinstallcx_Oracle==7.3
獲取oracle表信息
catquery_oracle.py
#!/usr/bin/envpython
importcx_Oracle
importsys
importos
importcsv
importtraceback
file=open("oracle.txt",'w').close()
user="test"
passwd="test"
listener='5:1521/orcl'
conn=cx_Oracle.connect(user,passwd,listener)
cursor=conn.cursor()
sql="selecttable_namefromuser_tables"
cursor.execute(sql)
LIST1=[]
whileTrue:
row=cursor.fetchone()
ifrow==None:
break
fortableinrow:
#printtable
LIST1.append(table)
LIST2=[]
foriinLIST1:
sql3="selectCOLUMN_NAME,DATA_TYPE,DATA_PRECISION,DATA_SCALEfromcolsWHERETABLE_name=upper('%s')"%i
cursor.execute(sql3)
cursor.execute(sql3)
row3=cursor.fetchall()
fordatainrow3:
#LIST2.append(i)
LIST2.extend(list(data))
LIST2.append(i)
f=open('oracle.txt','a+')
printf,LIST2
LIST2=[]
#f=open('test.txt','a+')
#selecttable_name,column_name,DATA_TYPEfromcolsWHERETABLE_name=upper('student');
#selectcolumn_name,DATA_TYPEfromcolsWHERETABLE_name=upper('student');
去掉多余部分
catauto.sh
#!/bin/bash
#pythonquery_oracle.py|tr","''|tr"'"''|tr"["""|tr"]"""
#oracle.txt
oracle_tables.txt
catoracle.txt|tr"[],'"""|sed"s#[][]*##g"|sed's/^[\t]*//g'oracle_tables.txt
catoracle_tables.txt
SNONUMBER190SNAMEVARCHAR2NoneNoneSSEXVARCHAR2NoneNoneSBIRTHDAYDATENoneNoneSCLASSVARCHAR2NoneNoneSTUDENTDATE_DATE
SNO2NUMBER190SNAMEVARCHAR2NoneNoneSSEXVARCHAR2NoneNoneSBIRTHDAYDATENoneNoneSCLASSVARCHAR2NoneNoneSTUDENT2INPUT_TIME
SNO3NUMBER192SNAMEVARCHAR2NoneNoneSSEXVARCHAR2NoneNoneSBIRTHDAYDATENoneNoneSCLASSVARCHAR2NoneNoneSTUDENT3DATA_DATE
shell腳本處理表信息文件
catconnect.sh
#!/bin/bash
#獲取臨時(shí)文件的行數(shù)
FILE_NUM=$(catoracle_tables.txt|egrep-v'#|^$'|wc-l)
#清空自動(dòng)創(chuàng)建連接器的腳本
create-connect.sh
#循環(huán)臨時(shí)文件每一行
foriin`seq$FILE_NUM`
FILE_LINE=$(sed-n${i}poracle_tables.txt)
TABLE_NAME=$(echo${FILE_LINE}|sed's/[\t]*$//g'|awk'{print$(NF-1)}')
COL_NUM=$(echo${FILE_LINE}|sed's/[\t]*$//g'|awk-F"[]"'{printNF}')
REAL_COL_NUM=`expr$COL_NUM-2`
#清空臨時(shí)文件
${TABLE_NAME}.txt
${TABLE_NAME}.sql
#循環(huán)臨時(shí)文件每行列名所在的列
forjin`seq14$REAL_COL_NUM`
k=`expr$j+1`
m=`expr$j+2`
n=`expr$j+3`
COL_NAME=$(echo$FILE_LINE|cut-d""-f${j})
COL_DATA_TYPE=$(echo$FILE_LINE|cut-d""-f${k})
COL_DATA_PRECISION=$(echo$FILE_LINE|cut-d""-f${m})
COL_DATA_SCALE=$(echo$FILE_LINE|cut-d""-f${n})
#判斷列的數(shù)據(jù)類(lèi)型是否是NUMBER
if["$COL_DATA_TYPE"="NUMBER"]
then
#循環(huán)拼接SQL查詢(xún)中的CAST(*AS*)AS*部分,追加到臨時(shí)文件中
echo"CAST($COL_NAMEAS$COL_DATA_TYPE($COL_DATA_PRECISION,$COL_DATA_SCALE))AS$COL_NAME"${TABLE_NAME}.txt
else
#循環(huán)拼接SQL查詢(xún)中的列名部分,追加到臨時(shí)文件中
echo"$COL_NAME"${TABLE_NAME}.txt
done
#拼接完整的SQL語(yǔ)句,追加到臨時(shí)文件中
echo"select$(cat${TABLE_NAME}.txt|tr"\n"","|sed-e's/,$/\n/')from$TABLE_NAMEwhere$(sed-n${i}poracle_tables.txt|cut-d''-f$COL_NUM)=trunc(sysdate-2)and$(sed-n${i}poracle_tables.txt|cut-d''-f$COL_NUM)trunc(sysdate-1)"${TABLE_NAME}.sql
#循環(huán)追加每個(gè)表對(duì)應(yīng)的連接器到自動(dòng)創(chuàng)建連接器的腳本中
catcreate-connect.shEOF
curl-XPOSThttp://localhost:8083/connectors-H"Content-Type:application/json"-d'{
"name":"jdbc_source_$TABLE_NAME",
"config":{
"connector.class":"io.confluent.connect.jdbc.JdbcSourceConnector",
"connection.url":"jdbc:oracle:thin:@{{ORACLE_IP}}:{{ORACLE_PORT}}:orcl",
"connection.user":"{{ORACLE_USER}}",
"connection.password":"{{ORACLE_PASSWD}}",
"topic.prefix":"YC_$TABLE_NAME",
"mode":"{{CONNECT_MODE}}",
"query":"$(cat${TABLE_NAME}.sql)"
}'/dev/null21
說(shuō)明:腳本中{{變量名}}部分的內(nèi)容是獲取ansible中的變量,這個(gè)腳本是和ansible結(jié)合使用的。
增強(qiáng)版處理表信息腳本
#!/bin/bash
#獲取臨時(shí)文件的行數(shù)
FILE_NUM=$(catoracle_time_tables.txt|egrep-v'#|^$'|wc-l)
#清空創(chuàng)建連接器的腳本并追加echos函數(shù)
create-jdbc-connect.sh
catcreate-jdbc-connect.shEOF
#!/bin/bash
echos(){
case\$1in
red)echo-e"\033[31m\$2\033[0m";;
green)echo-e"\033[32m\$2\033[0m";;
yellow)echo-e"\033[33m\$2\033[0m";;
blue)echo-e"\033[34m\$2\033[0m";;
purple)echo-e"\033[35m\$2\033[0m";;
*)echo"\$2";;
create-jdbc-connect-time.sh
catcreate-jdbc-connect-time.shEOF
#!/bin/bash
echos(){
case\$1in
red)echo-e"\033[31m\$2\033[0m";;
green)echo-e"\033[32m\$2\033[0m";;
yellow)echo-e"\033[33m\$2\033[0m";;
blue)echo-e"\033[34m\$2\033[0m";;
purple)echo-e"\033[35m\$2\033[0m";;
*)echo"\$2";;
#創(chuàng)建表相關(guān)文件目錄
mkdir-p./TABLE_TIME
#循環(huán)臨時(shí)文件每一行
foriin`seq$FILE_NUM`
FILE_LINE=$(sed-n${i}poracle_time_tables.txt)
TABLE_NAME=$(echo${FILE_LINE}|sed's/[\t]*$//g'|awk'{print$(NF)}')
COL_NUM=$(echo${FILE_LINE}|sed's/[\t]*$//g'|awk-F"[]"'{printNF}')
REAL_COL_NUM=`expr$COL_NUM-2`
#清空臨時(shí)文件
./TABLE_TIME/${TABLE_NAME}_time.txt
./TABLE_TIME/${TABLE_NAME}_time.sql
./TABLE_TIME/${TABLE_NAME}.sql
#循環(huán)臨時(shí)文件每行列名所在的列
forjin`seq14$REAL_COL_NUM`
k=`expr$j+1`
m=`expr$j+2`
n=`expr$j+3`
COL_NAME=$(echo$FILE_LINE|cut-d""-f${j})
COL_DATA_TYPE=$(echo$FILE_LINE|cut-d""-f${k})
COL_DATA_PRECISION=$(echo$FILE_LINE|cut-d""-f${m})
COL_DATA_SCALE=$(echo$FILE_LINE|cut-d""-f${n})
#判斷列的數(shù)據(jù)類(lèi)型是否是NUMBER
if["$COL_DATA_TYPE"="NUMBER"]
then
#循環(huán)拼接SQL查詢(xún)中的CAST(*AS*)AS*部分,追加到臨時(shí)文件中
echo"CAST($COL_NAMEAS$COL_DATA_TYPE($COL_DATA_PRECISION,$COL_DATA_SCALE))AS$COL_NAME"./TABLE_TIME/${TABLE_NAME}_time.txt
else
#循環(huán)拼接SQL查詢(xún)中的列名部分,追加到臨時(shí)文件中
echo"$COL_NAME"./TABLE_TIME/${TABLE_NAME}_time.txt
#判斷是否存在hosts中定義的時(shí)間列,如果有就追加該列名進(jìn)一個(gè)臨時(shí)文件中
TIME_COL=({{TABLE_TIME_COL}})
forTIMEin${TIME_COL[@]}
if["$COL_NAME"="$TIME"]
then
echo"$COL_NAME"./TABLE_TIME/${TABLE_NAME}_TIME_COL.txt
done
done
#拼接完整的SQL語(yǔ)句,追加到臨時(shí)文件中
if[-f"./TABLE_TIME/${TABLE_NAME}_TIME_COL.txt"]
then
#echo"select$(cat./TABLE_TIME/${TABLE_NAME}.txt|tr"\n"","|sed-e's/,$/\n/')from{{ORACLE_TABLES_USER}}.$TABLE_NAMEwhere$(sed-n${i}poracle_tables.txt|cut-d''-f$COL_NUM)=trunc(sysdate-2)and$(sed-n${i}poracle_tables.txt|cut-d''-f$COL_NUM)trunc(sysdate-1)"./TABLE_TIME/${TABLE_NAME}_time.sql
echo"select$(cat./TABLE_TIME/${TABLE_NAME}_time.txt|tr"\n"","|sed-e's/,$/\n/')from{{ORACLE_TABLES_USER}}.$TABLE_NAMEwhere$(cat./TABLE_TIME/${TABLE_NAME}_TIME_COL.txt)=trunc(sysdate-2)and$(cat./TABLE_TIME/${TABLE_NAME}_TIME_COL.txt)trunc(sysdate-1)"./TABLE_TIME/${TABLE_NAME}_time.sql
else
echo"select$(cat./TABLE_TIME/${TABLE_NAME}_time.txt|tr"\n"","|sed-e's/,$/\n/')from{{ORACLE_TABLES_USER}}.$TABLE_NAME"./TABLE_TIME/${TABLE_NAME}.sql
#循環(huán)追加每個(gè)表對(duì)應(yīng)的連接器到自動(dòng)創(chuàng)建連接器的腳本中
if[-f"./TABLE_TIME/${TABLE_NAME}_TIME_COL.txt"]
catcreate-jdbc-connect-time.shEOF
#創(chuàng)建表$TABLE_NAME連接器的命令如下
curl-XPOSThttp://localhost:8083/connectors-H"Content-Type:application/json"-d'{
"name":"jdbc_time_$TABLE_NAME",
"config":{
"connector.class":"io.confluent.connect.jdbc.JdbcSourceConnector",
"connection.url":"jdbc:oracle:thin:@{{ORACLE_IP}}:{{ORACLE_PORT}}:{{ORACLE_SERVER_NAME}}",
"connection.user":"{{ORACLE_USER}}",
"connection.password":"{{ORACLE_PASSWD}}",
"topic.prefix":"YC_${TABLE_NAME}_INSERT",
"erval.ms":"86400000",
"mode":"{{CONNECT_MODE}}",
"numeric.mapping":"best_fit",
"query":"$(cat./TABLE_TIME/${TABLE_NAME}_time.sql)"
}'/dev/null21
#判斷連接器是否創(chuàng)建成功
if[\$-eq0]
echosgreen"\$(date+"%F%H:%M:%S")創(chuàng)建jdbc_time_${TABLE_NAME}連
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶(hù)所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶(hù)上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶(hù)上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶(hù)因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 2025年紫外激光傳輸光纖合作協(xié)議書(shū)
- 2025年醫(yī)療儀器設(shè)備制造項(xiàng)目發(fā)展計(jì)劃
- 教育與商業(yè)的融合以大數(shù)據(jù)分析支持學(xué)生個(gè)性化發(fā)展
- 家庭教育心理學(xué)塑造孩子健康人格的技巧
- 2025屆安徽省 馬鞍山中加雙語(yǔ)學(xué)校高二物理第二學(xué)期期末監(jiān)測(cè)模擬試題含解析
- 教育技術(shù)與家長(zhǎng)參與的個(gè)性化學(xué)習(xí)模式研究
- 智慧醫(yī)療的AI助手智能輔導(dǎo)系統(tǒng)的應(yīng)用與挑戰(zhàn)
- 企業(yè)人才培養(yǎng)中的信息技術(shù)應(yīng)用分析
- 大數(shù)據(jù)在提升學(xué)生綜合素質(zhì)評(píng)價(jià)中的應(yīng)用
- 2025屆陜西省旬陽(yáng)中學(xué)物理高二下期末檢測(cè)試題含解析
- 抖音技巧培訓(xùn)課件
- 職業(yè)規(guī)劃樂(lè)高老師課件
- 2025至2030中國(guó)體育行業(yè)市場(chǎng)發(fā)展分析及前景趨勢(shì)與投資機(jī)會(huì)報(bào)告
- 建設(shè)工程廣聯(lián)達(dá)算量標(biāo)準(zhǔn)化要求(內(nèi)部標(biāo)準(zhǔn))
- 路燈安裝考試試題及答案
- 赤峰市翁牛特旗招聘社區(qū)工作者筆試真題2024
- 線上游戲賬號(hào)及虛擬物品交易合同
- 2025至2030全球及中國(guó)家用濕巾行業(yè)發(fā)展趨勢(shì)分析與未來(lái)投資戰(zhàn)略咨詢(xún)研究報(bào)告
- 市場(chǎng)監(jiān)管培訓(xùn)
- 2025至2030中國(guó)電鍍鋅鋼行業(yè)發(fā)展趨勢(shì)分析與未來(lái)投資戰(zhàn)略咨詢(xún)研究報(bào)告
- 山西省2025年中考語(yǔ)文真題(含答案)
評(píng)論
0/150
提交評(píng)論