Jianghan 2 yıl önce
ebeveyn
işleme
b93b80e680

+ 8 - 3
proposed_project/common.toml

@@ -11,12 +11,12 @@ locport = ":17821"
 
 [db]
 [db.mysql]
-addr = "192.168.3.14:4000"
+addr = "192.168.3.217:4000"
 dbnameBasic = "global_common_data"
-dbnameMedical = "medical_field_data_dev"
+dbnameMedical = "Jianyu_subjectdb"
 size = 5
 user = "root"
-password = "Tibi#20211222"
+password = "=PDT49#80Z!RVv52_z"
 
 maxidle = 10
 maxconn = 20
@@ -38,6 +38,11 @@ size = 15
 user = ""
 password = ""
 
+[db.es]
+addr = "http://127.0.0.1:9200"
+size = 5
+indexP = "proposed_v1"
+
 [mail]
 send = false
 to = "wangjianghan@topnet.net.cn"

+ 7 - 0
proposed_project/config/conf.go

@@ -41,6 +41,12 @@ type udp struct {
 	LocPort string
 }
 
+type es struct {
+	Addr   string
+	Size   int
+	IndexP string
+}
+
 type mail struct {
 	Send bool
 	To   string
@@ -62,6 +68,7 @@ type db struct {
 	MongoB mgo
 	MongoP mgo
 	Mysql  mysql
+	Es     es
 }
 
 type mgo struct {

+ 13 - 1
proposed_project/config/conf_test.go

@@ -13,6 +13,18 @@ jyaddr = "127.0.0.1"
 jyport = 11118
 
 [db]
+[db.mysql]
+addr = "192.168.3.14:4000"
+dbnameBasic = "global_common_data"
+dbnameMedical = "Jianyu_subjectdb"
+size = 5
+user = "root"
+password = "Tibi#20211222"
+
+maxidle = 10
+maxconn = 20
+maxquerytime = "10s"
+
 [db.mongoB]
 addr = "192.168.3.207:27092"
 dbname = "wjh"
@@ -189,6 +201,6 @@ func TestInit(t *testing.T) {
 	testfile := "/tmp/crocodile.toml"
 	ioutil.WriteFile(testfile, []byte(confs), 0644)
 	Init(testfile)
-	t.Logf("%+v", Conf.DB.Es.FieldPurchasingList)
+	t.Logf("%+v", Conf.DB.Mysql.DbnameMedical)
 	os.Remove(testfile)
 }

+ 3 - 2
proposed_project/go.mod

@@ -3,10 +3,11 @@ module proposed_project
 go 1.16
 
 require (
-	app.yhyue.com/data_processing/common_utils v0.0.0-20220927054143-d9e97522625d
+	app.yhyue.com/data_processing/common_utils v0.0.0-20230222101125-ea9695b3561b
 	github.com/BurntSushi/toml v1.2.0
+	github.com/olivere/elastic/v7 v7.0.32 // indirect
 	github.com/robfig/cron v1.2.0
 	github.com/spf13/cobra v1.6.1
-	go.mongodb.org/mongo-driver v1.10.3 // indirect
+	go.mongodb.org/mongo-driver v1.10.3
 	go.uber.org/zap v1.23.0
 )

+ 126 - 5
proposed_project/go.sum

@@ -1,30 +1,93 @@
-app.yhyue.com/data_processing/common_utils v0.0.0-20220927054143-d9e97522625d h1:Nh2rC3LBqh0alvam2vr4is/vbUaPkl0rbZxVETx3nmk=
-app.yhyue.com/data_processing/common_utils v0.0.0-20220927054143-d9e97522625d/go.mod h1:9PlRUNzirlF/LL1W7fA7koCudxJe3uO5nshDWlCnGo8=
+app.yhyue.com/data_processing/common_utils v0.0.0-20230222015601-4aa9cd9a4b1f h1:fgIB/YVMLhvM8z5L78dFmrp6+jkuaSFJvFQDK5QLLHA=
+app.yhyue.com/data_processing/common_utils v0.0.0-20230222015601-4aa9cd9a4b1f/go.mod h1:ZElBBWNe2wxuDz83hTNWvvjO+lhhWNfYDtdfnS+CaXQ=
+app.yhyue.com/data_processing/common_utils v0.0.0-20230222023157-8ce3078de243 h1:jIhn9RlTGIzz3uVJ2mCe9Bk5wXv/nWKats94AykLlBo=
+app.yhyue.com/data_processing/common_utils v0.0.0-20230222023157-8ce3078de243/go.mod h1:ZElBBWNe2wxuDz83hTNWvvjO+lhhWNfYDtdfnS+CaXQ=
+app.yhyue.com/data_processing/common_utils v0.0.0-20230222023810-f1970b57de58 h1:MKPrDciU60/MzuFofzHQ5paJIepKRbPodM0rMx70cAw=
+app.yhyue.com/data_processing/common_utils v0.0.0-20230222023810-f1970b57de58/go.mod h1:ZElBBWNe2wxuDz83hTNWvvjO+lhhWNfYDtdfnS+CaXQ=
+app.yhyue.com/data_processing/common_utils v0.0.0-20230222024924-8abe1226ecca h1:V9ztsNI2iUxSWDMI4XRaAKXi96A9gEfkR6cWJRNXnRg=
+app.yhyue.com/data_processing/common_utils v0.0.0-20230222024924-8abe1226ecca/go.mod h1:ZElBBWNe2wxuDz83hTNWvvjO+lhhWNfYDtdfnS+CaXQ=
+app.yhyue.com/data_processing/common_utils v0.0.0-20230222031328-4da4106979b9 h1:/os8xMs+R5VTAB+bzL2SuXOf3Kx3Mf9ZQLZervtG+XE=
+app.yhyue.com/data_processing/common_utils v0.0.0-20230222031328-4da4106979b9/go.mod h1:ZElBBWNe2wxuDz83hTNWvvjO+lhhWNfYDtdfnS+CaXQ=
+app.yhyue.com/data_processing/common_utils v0.0.0-20230222062821-f5239e6b315e h1:3RfjAUWrZnQ3jPtfbtkdVvdZKBE1w8skgOGSfLyDDTA=
+app.yhyue.com/data_processing/common_utils v0.0.0-20230222062821-f5239e6b315e/go.mod h1:ZElBBWNe2wxuDz83hTNWvvjO+lhhWNfYDtdfnS+CaXQ=
+app.yhyue.com/data_processing/common_utils v0.0.0-20230222094654-3d67d7cca1a0 h1:l9ZfRAm3FmrXTOt6b91cSQajLgO+MrFS/jCwznuPc/U=
+app.yhyue.com/data_processing/common_utils v0.0.0-20230222094654-3d67d7cca1a0/go.mod h1:XMSY6tIzDnO/YQFjSb0OrOKl93ViGE0ejqcSCTlyHUs=
+app.yhyue.com/data_processing/common_utils v0.0.0-20230222095314-1af0d77bb38f h1:HUwCSwtUydzODuV0Mx593w4NXU5dUf6GTYkBi02/l8I=
+app.yhyue.com/data_processing/common_utils v0.0.0-20230222095314-1af0d77bb38f/go.mod h1:XMSY6tIzDnO/YQFjSb0OrOKl93ViGE0ejqcSCTlyHUs=
+app.yhyue.com/data_processing/common_utils v0.0.0-20230222101125-ea9695b3561b h1:uEgyZ+6f0loZGN4NNZvcsfEIsg1GYRwMhowvs4pdPEQ=
+app.yhyue.com/data_processing/common_utils v0.0.0-20230222101125-ea9695b3561b/go.mod h1:XMSY6tIzDnO/YQFjSb0OrOKl93ViGE0ejqcSCTlyHUs=
+app.yhyue.com/data_processing/common_utils v0.0.0-20230222101737-6ffa95c794d8 h1:2e+sX/Lh6d2Dmwnu3tqBVoTmbVQilrg8C7e1nPSHWT0=
+app.yhyue.com/data_processing/common_utils v0.0.0-20230222101737-6ffa95c794d8/go.mod h1:XMSY6tIzDnO/YQFjSb0OrOKl93ViGE0ejqcSCTlyHUs=
+app.yhyue.com/data_processing/common_utils v0.0.0-20230222102112-b29fe41c56c0 h1:5MA02KuS5Q24jbiJaQH2+6mEdPcnj3Zm1a7EIkQHoMc=
+app.yhyue.com/data_processing/common_utils v0.0.0-20230222102112-b29fe41c56c0/go.mod h1:XMSY6tIzDnO/YQFjSb0OrOKl93ViGE0ejqcSCTlyHUs=
+cloud.google.com/go v0.26.0/go.mod h1:aQUYkXzVsufM+DwF1aE+0xfcU+56JwCaLick0ClmMTw=
+github.com/BurntSushi/toml v0.3.1/go.mod h1:xHWCNGjB5oqiDr8zfno3MHue2Ht5sIBksp03qcyfWMU=
 github.com/BurntSushi/toml v1.2.0 h1:Rt8g24XnyGTyglgET/PRUNlrUeu9F5L+7FilkXfZgs0=
 github.com/BurntSushi/toml v1.2.0/go.mod h1:CxXYINrC8qIiEnFrOxCa7Jy5BFHlXnUU2pbicEuybxQ=
 github.com/PuerkitoBio/goquery v1.8.0 h1:PJTF7AmFCFKk1N6V6jmKfrNH9tV5pNE6lZMkG0gta/U=
 github.com/PuerkitoBio/goquery v1.8.0/go.mod h1:ypIiRMtY7COPGk+I/YbZLbxsxn9g5ejnI2HSMtkjZvI=
 github.com/andybalholm/cascadia v1.3.1 h1:nhxRkql1kdYCc8Snf7D5/D3spOX+dBgjA6u8x004T2c=
 github.com/andybalholm/cascadia v1.3.1/go.mod h1:R4bJ1UQfqADjvDa4P6HZHLh/3OxWWEqc0Sk8XGwHqvA=
+github.com/aws/aws-sdk-go v1.43.21 h1:E4S2eX3d2gKJyI/ISrcIrSwXwqjIvCK85gtBMt4sAPE=
+github.com/aws/aws-sdk-go v1.43.21/go.mod h1:y4AeaBuwd2Lk+GepC1E9v0qOiTws0MIWAX4oIKwKHZo=
 github.com/benbjohnson/clock v1.1.0 h1:Q92kusRqC1XV2MjkWETPvjJVqKetz1OzxZB7mHJLju8=
 github.com/benbjohnson/clock v1.1.0/go.mod h1:J11/hYXuz8f4ySSvYwY0FKfm+ezbsZBKZxNJlLklBHA=
+github.com/census-instrumentation/opencensus-proto v0.2.1/go.mod h1:f6KPmirojxKA12rnyqOA5BBL4O983OfeGPqjHWSTneU=
+github.com/client9/misspell v0.3.4/go.mod h1:qj6jICC3Q7zFZvVWo7KLAzC3yx5G7kyvSDkc90ppPyw=
+github.com/cncf/udpa/go v0.0.0-20191209042840-269d4d468f6f/go.mod h1:M8M6+tZqaGXZJjfX53e64911xZQV5JYwmTeXPW+k8Sc=
 github.com/cpuguy83/go-md2man/v2 v2.0.2/go.mod h1:tgQtvFlXSQOSOSIRvRPT7W67SCa46tRHOmNcaadrF8o=
 github.com/davecgh/go-spew v1.1.0/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38=
 github.com/davecgh/go-spew v1.1.1 h1:vj9j/u1bqnvCEfJOwUhtlOARqs3+rkHYY13jYWTU97c=
 github.com/davecgh/go-spew v1.1.1/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38=
 github.com/dchest/captcha v1.0.0 h1:vw+bm/qMFvTgcjQlYVTuQBJkarm5R0YSsDKhm1HZI2o=
 github.com/dchest/captcha v1.0.0/go.mod h1:7zoElIawLp7GUMLcj54K9kbw+jEyvz2K0FDdRRYhvWo=
+github.com/envoyproxy/go-control-plane v0.9.0/go.mod h1:YTl/9mNaCwkRvm6d1a2C3ymFceY/DCBVvsKhRF0iEA4=
+github.com/envoyproxy/go-control-plane v0.9.1-0.20191026205805-5f8ba28d4473/go.mod h1:YTl/9mNaCwkRvm6d1a2C3ymFceY/DCBVvsKhRF0iEA4=
+github.com/envoyproxy/go-control-plane v0.9.4/go.mod h1:6rpuAdCZL397s3pYoYcLgu1mIlRU8Am5FuJP05cCM98=
+github.com/envoyproxy/protoc-gen-validate v0.1.0/go.mod h1:iSmxcyjqTsJpI2R4NaDN7+kN2VEUnK/pcBlmesArF7c=
+github.com/fortytw2/leaktest v1.3.0 h1:u8491cBMTQ8ft8aeV+adlcytMZylmA5nnwwkRZjI8vw=
 github.com/fortytw2/leaktest v1.3.0/go.mod h1:jDsjWgpAGjm2CA7WthBh/CdZYEPF31XHquHwclZch5g=
+github.com/go-logr/logr v1.2.2 h1:ahHml/yUpnlb96Rp8HCvtYVPY8ZYpxq3g7UYchIYwbs=
+github.com/go-logr/logr v1.2.2/go.mod h1:jdQByPbusPIv2/zmleS9BjJVeZ6kBagPoEUsqbVz/1A=
+github.com/go-logr/stdr v1.2.2 h1:hSWxHoqTgW2S2qGc0LTAI563KZ5YKYRhT3MFKZMbjag=
+github.com/go-logr/stdr v1.2.2/go.mod h1:mMo/vtBO5dYbehREoey6XUKy/eSumjCCveDpRre4VKE=
 github.com/go-sql-driver/mysql v1.6.0 h1:BCTh4TKNUYmOmMUcQ3IipzF5prigylS7XXjEkfCHuOE=
 github.com/go-sql-driver/mysql v1.6.0/go.mod h1:DCzpHaOWr8IXmIStZouvnhqoel9Qv2LBy8hT2VhHyBg=
+github.com/golang/glog v0.0.0-20160126235308-23def4e6c14b/go.mod h1:SBH7ygxi8pfUlaOkMMuAQtPIUF8ecWP5IEl/CR7VP2Q=
+github.com/golang/groupcache v0.0.0-20200121045136-8c9f03a8e57e/go.mod h1:cIg4eruTrX1D+g88fzRXU5OdNfaM+9IcxsU14FzY7Hc=
+github.com/golang/groupcache v0.0.0-20210331224755-41bb18bfe9da h1:oI5xCqsCo564l8iNU+DwB5epxmsaqB+rhGL0m5jtYqE=
+github.com/golang/groupcache v0.0.0-20210331224755-41bb18bfe9da/go.mod h1:cIg4eruTrX1D+g88fzRXU5OdNfaM+9IcxsU14FzY7Hc=
+github.com/golang/mock v1.1.1/go.mod h1:oTYuIxOrZwtPieC+H1uAHpcLFnEyAGVDL/k47Jfbm0A=
+github.com/golang/protobuf v1.2.0/go.mod h1:6lQm79b+lXiMfvg/cZm0SGofjICqVBUtrP5yJMmIC1U=
+github.com/golang/protobuf v1.3.2/go.mod h1:6lQm79b+lXiMfvg/cZm0SGofjICqVBUtrP5yJMmIC1U=
+github.com/golang/protobuf v1.4.0-rc.1/go.mod h1:ceaxUfeHdC40wWswd/P6IGgMaK3YpKi5j83Wpe3EHw8=
+github.com/golang/protobuf v1.4.0-rc.1.0.20200221234624-67d41d38c208/go.mod h1:xKAWHe0F5eneWXFV3EuXVDTCmh+JuBKY0li0aMyXATA=
+github.com/golang/protobuf v1.4.0-rc.2/go.mod h1:LlEzMj4AhA7rCAGe4KMBDvJI+AwstrUpVNzEA03Pprs=
+github.com/golang/protobuf v1.4.0-rc.4.0.20200313231945-b860323f09d0/go.mod h1:WU3c8KckQ9AFe+yFwt9sWVRKCVIyN9cPHBJSNnbL67w=
+github.com/golang/protobuf v1.4.0/go.mod h1:jodUvKwWbYaEsadDk5Fwe5c77LiNKVO9IDvqG2KuDX0=
+github.com/golang/protobuf v1.4.1/go.mod h1:U8fpvMrcmy5pZrNK1lt4xCsGvpyWQ/VVv6QDs8UjoX8=
+github.com/golang/protobuf v1.4.3/go.mod h1:oDoupMAO8OvCJWAcko0GGGIgR6R6ocIYbsSw735rRwI=
 github.com/golang/snappy v0.0.1 h1:Qgr9rKW7uDUkrbSmQeiDsGa8SjGyCOGtuasMWwvp2P4=
 github.com/golang/snappy v0.0.1/go.mod h1:/XxbfmMg8lxefKM7IXC3fBNl/7bRcc72aCRzEWrmP2Q=
 github.com/gomodule/redigo v1.8.9 h1:Sl3u+2BI/kk+VEatbj0scLdrFhjPmbxOc1myhDP41ws=
 github.com/gomodule/redigo v1.8.9/go.mod h1:7ArFNvsTjH8GMMzB4uy1snslv2BwmginuMs06a1uzZE=
-github.com/google/go-cmp v0.5.2 h1:X2ev0eStA3AbceY54o37/0PQ/UWqKEiiO2dKL5OPaFM=
+github.com/google/go-cmp v0.2.0/go.mod h1:oXzfMopK8JAjlY9xF4vHSVASa0yLyX7SntLO5aqRK0M=
+github.com/google/go-cmp v0.3.0/go.mod h1:8QqcDgzrUqlUb/G2PQTWiueGozuR1884gddMywk6iLU=
+github.com/google/go-cmp v0.3.1/go.mod h1:8QqcDgzrUqlUb/G2PQTWiueGozuR1884gddMywk6iLU=
+github.com/google/go-cmp v0.4.0/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE=
+github.com/google/go-cmp v0.5.0/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE=
 github.com/google/go-cmp v0.5.2/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE=
+github.com/google/go-cmp v0.5.3/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE=
+github.com/google/go-cmp v0.5.7 h1:81/ik6ipDQS2aGcBfIN5dHDB36BwrStyeAQquSYCV4o=
+github.com/google/go-cmp v0.5.7/go.mod h1:n+brtR0CgQNWTVd5ZUFpTBC8YFBDLK/h/bpaJ8/DtOE=
+github.com/google/uuid v1.1.2/go.mod h1:TIyPZe4MgqvfeYDBFedMoGGpEw/LqOeaOT+nhxU+yHo=
 github.com/inconshreveable/mousetrap v1.0.1 h1:U3uMjPSQEBMNp1lFxmllqCPM6P5u/Xq7Pgzkat/bFNc=
 github.com/inconshreveable/mousetrap v1.0.1/go.mod h1:vpF70FUmC8bwa3OWnCshd2FqLfsEA9PFc4w1p2J65bw=
+github.com/jmespath/go-jmespath v0.4.0 h1:BEgLn5cpjn8UN1mAw4NjwDrS35OdebyEtFe+9YPoQUg=
+github.com/jmespath/go-jmespath v0.4.0/go.mod h1:T8mJZnbsbmF+m6zOOFylbeCJqk5+pHWvzYPziyZiYoo=
+github.com/jmespath/go-jmespath/internal/testify v1.5.1/go.mod h1:L3OGu8Wl2/fWfCI6z80xFu9LTZmf1ZRjMHUOPmWr69U=
+github.com/josharian/intern v1.0.0 h1:vlS4z54oSdjm0bgjRigI+G1HpF+tI+9rE5LLzOg8HmY=
+github.com/josharian/intern v1.0.0/go.mod h1:5DoeVV0s6jJacbCEi61lwdGj/aVlrQvzHFFd8Hwg//Y=
 github.com/klauspost/compress v1.13.6 h1:P76CopJELS0TiO2mebmnzgWaajssP/EszplttgQxcgc=
 github.com/klauspost/compress v1.13.6/go.mod h1:/3/Vjq9QcHkK5uEr5lBEmyoZ1iFhe47etQ6QUkpK6sk=
 github.com/kr/pretty v0.1.0 h1:L/CwN0zerZDmRFUapSPitk6f+Q3+0za1rQkzVuMiMFI=
@@ -32,17 +95,28 @@ github.com/kr/pretty v0.1.0/go.mod h1:dAy3ld7l9f0ibDNOQOHHMYYIIbhfbHSm3C4ZsoJORN
 github.com/kr/pty v1.1.1/go.mod h1:pFQYn66WHrOpPYNljwOMqo10TkYh1fy3cYio2l3bCsQ=
 github.com/kr/text v0.1.0 h1:45sCR5RtlFHMR4UwH9sdQ5TC8v0qDQCHnXt+kaKSTVE=
 github.com/kr/text v0.1.0/go.mod h1:4Jbv+DJW3UT/LiOwJeYQe1efqtUx/iVham/4vfdArNI=
+github.com/mailru/easyjson v0.7.7 h1:UGYAvKxe3sBsEDzO8ZeWOSlIQfWFlxbzLZe7hwFURr0=
+github.com/mailru/easyjson v0.7.7/go.mod h1:xzfreul335JAWq5oZzymOObrkdz5UnU4kGfJJLY9Nlc=
 github.com/montanaflynn/stats v0.0.0-20171201202039-1bf9dbcd8cbe h1:iruDEfMl2E6fbMZ9s0scYfZQ84/6SPL6zC8ACM2oIL0=
 github.com/montanaflynn/stats v0.0.0-20171201202039-1bf9dbcd8cbe/go.mod h1:wL8QJuTMNUDYhXwkmfOly8iTdp5TEcJFWZD2D7SIkUc=
 github.com/nsqio/go-nsq v1.1.0/go.mod h1:vKq36oyeVXgsS5Q8YEO7WghqidAVXQlcFxzQbQTuDEY=
+github.com/olivere/elastic/v7 v7.0.32 h1:R7CXvbu8Eq+WlsLgxmKVKPox0oOwAE/2T9Si5BnvK6E=
+github.com/olivere/elastic/v7 v7.0.32/go.mod h1:c7PVmLe3Fxq77PIfY/bZmxY/TAamBhCzZ8xDOE09a9k=
+github.com/opentracing/opentracing-go v1.2.0 h1:uEJPy/1a5RIPAJ0Ov+OIO8OxWu77jEv+1B0VhjKrZUs=
+github.com/opentracing/opentracing-go v1.2.0/go.mod h1:GxEUsuufX4nBwe+T+Wl9TAgYrxe9dPLANfrWvHYVTgc=
 github.com/pkg/errors v0.8.1/go.mod h1:bwawxfHBFNV+L2hUp1rHADufV3IMtnDRdf1r5NINEl0=
 github.com/pkg/errors v0.9.1 h1:FEBLx1zS214owpjy7qsBeixbURkuhQAwrK5UwLGTwt4=
 github.com/pkg/errors v0.9.1/go.mod h1:bwawxfHBFNV+L2hUp1rHADufV3IMtnDRdf1r5NINEl0=
 github.com/pmezard/go-difflib v1.0.0 h1:4DBwDE0NGyQoBHbLQYPwSUPoCMWR5BEzIk/f1lZbAQM=
 github.com/pmezard/go-difflib v1.0.0/go.mod h1:iKH77koFhYxTK1pcRnkKkqfTogsbg7gZNVY4sRDYZ/4=
+github.com/prometheus/client_model v0.0.0-20190812154241-14fe0d1b01d4/go.mod h1:xMI15A0UPsDsEKsMN9yxemIoYk6Tm2C1GtYGdfGttqA=
 github.com/robfig/cron v1.2.0 h1:ZjScXvvxeQ63Dbyxy76Fj3AT3Ut0aKsyd2/tl3DTMuQ=
 github.com/robfig/cron v1.2.0/go.mod h1:JGuDeoQd7Z6yL4zQhZ3OPEVHB7fL6Ka6skscFHfmt2k=
 github.com/russross/blackfriday/v2 v2.1.0/go.mod h1:+Rmxgy9KzJVeS9/2gXHxylqXiyQDYRxCVz55jmeOWTM=
+github.com/smartystreets/assertions v1.1.1/go.mod h1:tcbTF8ujkAEcZ8TElKY+i30BzYlVhC/LOxJk7iOWnoo=
+github.com/smartystreets/go-aws-auth v0.0.0-20180515143844-0c1422d1fdb9 h1:hp2CYQUINdZMHdvTdXtPOY2ainKl4IoMcpAXEf2xj3Q=
+github.com/smartystreets/go-aws-auth v0.0.0-20180515143844-0c1422d1fdb9/go.mod h1:SnhjPscd9TpLiy1LpzGSKh3bXCfxxXuqd9xmQJy3slM=
+github.com/smartystreets/gunit v1.4.2/go.mod h1:ZjM1ozSIMJlAz/ay4SG8PeKF00ckUp+zMHZXV9/bvak=
 github.com/spf13/cobra v1.6.1 h1:o94oiPyS4KD1mPy2fmcYYHHfCxLqYjJOhGsCHFZtEzA=
 github.com/spf13/cobra v1.6.1/go.mod h1:IOw/AERYS7UzyrGinqmz6HLUo219MORXGxhbaJUqzrY=
 github.com/spf13/pflag v1.0.5 h1:iy+VFUOCP1a+8yFto/drg2CJ5u0yRoB7fZw3DKv/JXA=
@@ -69,6 +143,12 @@ github.com/yuin/goldmark v1.3.5/go.mod h1:mwnBkeHKe2W/ZEtQ+71ViKU8L12m81fl3OWwC1
 go.mongodb.org/mongo-driver v1.10.1/go.mod h1:z4XpeoU6w+9Vht+jAFyLgVrD+jGSQQe0+CBWFHNiHt8=
 go.mongodb.org/mongo-driver v1.10.3 h1:XDQEvmh6z1EUsXuIkXE9TaVeqHw6SwS1uf93jFs0HBA=
 go.mongodb.org/mongo-driver v1.10.3/go.mod h1:z4XpeoU6w+9Vht+jAFyLgVrD+jGSQQe0+CBWFHNiHt8=
+go.opencensus.io v0.23.0 h1:gqCw0LfLxScz8irSi8exQc7fyQ0fKQU/qnC/X8+V/1M=
+go.opencensus.io v0.23.0/go.mod h1:XItmlyltB5F7CS4xOC1DcqMoFqwtC6OG2xF7mCv7P7E=
+go.opentelemetry.io/otel v1.5.0 h1:DhCU8oR2sJH9rfnwPdoV/+BJ7UIN5kXHL8DuSGrPU8E=
+go.opentelemetry.io/otel v1.5.0/go.mod h1:Jm/m+rNp/z0eqJc74H7LPwQ3G87qkU/AnnAydAjSAHk=
+go.opentelemetry.io/otel/trace v1.5.0 h1:AKQZ9zJsBRFAp7zLdyGNkqG2rToCDIt3i5tcLzQlbmU=
+go.opentelemetry.io/otel/trace v1.5.0/go.mod h1:sq55kfhjXYr1zVSyexg0w1mpa03AYXR5eyTkB9NPPdE=
 go.uber.org/atomic v1.7.0 h1:ADUqmZGgLDDfbSL9ZmPxKTybcoEYHgpYfELNoN+7hsw=
 go.uber.org/atomic v1.7.0/go.mod h1:fEN4uk6kAWBTFdckzkM89CLk9XfWZrxpCo0nPH17wJc=
 go.uber.org/goleak v1.1.11 h1:wy28qYRKZgnJTxGxvye5/wgWr1EKjmUDGYox5mGlRlI=
@@ -80,35 +160,55 @@ go.uber.org/zap v1.23.0 h1:OjGQ5KQDEUawVHxNwQgPpiypGHOxo2mNZsOqTak4fFY=
 go.uber.org/zap v1.23.0/go.mod h1:D+nX8jyLsMHMYrln8A0rJjFt/T/9/bGgIhAqxv5URuY=
 golang.org/x/crypto v0.0.0-20190308221718-c2843e01d9a2/go.mod h1:djNgcEr1/C05ACkg1iLfiJU5Ep61QUkGW8qpdssI0+w=
 golang.org/x/crypto v0.0.0-20191011191535-87dc89f01550/go.mod h1:yigFU9vqHzYiE8UmvKecakEJjdnWj3jj499lnFckfCI=
+golang.org/x/crypto v0.0.0-20200622213623-75b288015ac9/go.mod h1:LzIPMQfyMNhhGPhUkYOs5KpL4U8rLKemX1yGLhDgUto=
 golang.org/x/crypto v0.0.0-20220622213112-05595931fe9d h1:sK3txAijHtOK88l68nt020reeT1ZdKLIYetKl95FzVY=
 golang.org/x/crypto v0.0.0-20220622213112-05595931fe9d/go.mod h1:IxCIyHEi3zRg3s0A5j5BB6A9Jmi73HwBIUl50j+osU4=
+golang.org/x/exp v0.0.0-20190121172915-509febef88a4/go.mod h1:CJ0aWSM057203Lf6IL+f9T1iT9GByDxfZKAQTCR3kQA=
+golang.org/x/lint v0.0.0-20181026193005-c67002cb31c3/go.mod h1:UVdnD1Gm6xHRNCYTkRU2/jEulfH38KcIWyp/GAMgvoE=
+golang.org/x/lint v0.0.0-20190227174305-5b3e6a55c961/go.mod h1:wehouNa3lNwaWXcvxsM5YxQ5yQlVC4a0KAMCusXpPoU=
+golang.org/x/lint v0.0.0-20190313153728-d0100b6bd8b3/go.mod h1:6SW0HCj/g11FgYtHlgUYUwCkIfeOF89ocIRzGO/8vkc=
 golang.org/x/lint v0.0.0-20190930215403-16217165b5de/go.mod h1:6SW0HCj/g11FgYtHlgUYUwCkIfeOF89ocIRzGO/8vkc=
 golang.org/x/mod v0.4.2/go.mod h1:s0Qsj1ACt9ePp/hMypM3fl4fZqREWJwdYDEqhRiZZUA=
+golang.org/x/net v0.0.0-20180724234803-3673e40ba225/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4=
+golang.org/x/net v0.0.0-20180826012351-8a410e7b638d/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4=
+golang.org/x/net v0.0.0-20190213061140-3a22650c66bd/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4=
 golang.org/x/net v0.0.0-20190311183353-d8887717615a/go.mod h1:t9HGtf8HONx5eT2rtn7q6eTqICYqUVnKs3thJo3Qplg=
 golang.org/x/net v0.0.0-20190404232315-eb5bcb51f2a3/go.mod h1:t9HGtf8HONx5eT2rtn7q6eTqICYqUVnKs3thJo3Qplg=
 golang.org/x/net v0.0.0-20190620200207-3b0461eec859/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s=
+golang.org/x/net v0.0.0-20201110031124-69a78807bb2b/go.mod h1:sp8m0HH+o8qH0wwXwYZr8TS3Oi6o0r6Gce1SSxlDquU=
 golang.org/x/net v0.0.0-20210405180319-a5a99cb37ef4/go.mod h1:p54w0d4576C0XHj96bSt6lcn1PtDYWL6XObtHCRCNQM=
 golang.org/x/net v0.0.0-20210916014120-12bc252f5db8/go.mod h1:9nx3DQGgdP8bBQD5qxJ1jj9UTztislL4KSBs9R2vV5Y=
-golang.org/x/net v0.0.0-20211112202133-69e39bad7dc2 h1:CIJ76btIcR3eFI5EgSo6k1qKw9KJexJuRLI9G7Hp5wE=
 golang.org/x/net v0.0.0-20211112202133-69e39bad7dc2/go.mod h1:9nx3DQGgdP8bBQD5qxJ1jj9UTztislL4KSBs9R2vV5Y=
+golang.org/x/net v0.0.0-20220127200216-cd36cc0744dd h1:O7DYs+zxREGLKzKoMQrtrEacpb0ZVXA5rIwylE2Xchk=
+golang.org/x/net v0.0.0-20220127200216-cd36cc0744dd/go.mod h1:CfG3xpIq0wQ8r1q4Su4UZFWDARRcnwPjda9FqA0JpMk=
+golang.org/x/oauth2 v0.0.0-20180821212333-d2e6202438be/go.mod h1:N/0e6XlmueqKjAGxoOufVs8QHGRruUQn6yWY3a++T0U=
+golang.org/x/sync v0.0.0-20180314180146-1d60e4601c6f/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
+golang.org/x/sync v0.0.0-20181108010431-42b317875d0f/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
 golang.org/x/sync v0.0.0-20190423024810-112230192c58/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
 golang.org/x/sync v0.0.0-20210220032951-036812b2e83c h1:5KslGYwFpkhGh+Q16bwMP3cOontH8FOep7tGV86Y7SQ=
 golang.org/x/sync v0.0.0-20210220032951-036812b2e83c/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
+golang.org/x/sys v0.0.0-20180830151530-49385e6e1522/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY=
 golang.org/x/sys v0.0.0-20190215142949-d0b11bdaac8a/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY=
 golang.org/x/sys v0.0.0-20190412213103-97732733099d/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
+golang.org/x/sys v0.0.0-20200930185726-fdedc70b468f/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
 golang.org/x/sys v0.0.0-20201119102817-f84b799fce68/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
 golang.org/x/sys v0.0.0-20210330210617-4fbd30eecc44/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
 golang.org/x/sys v0.0.0-20210423082822-04245dca01da/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
 golang.org/x/sys v0.0.0-20210510120138-977fb7262007/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
 golang.org/x/sys v0.0.0-20210615035016-665e8c7367d1/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
+golang.org/x/sys v0.0.0-20211216021012-1d35b9e2eb4e/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
 golang.org/x/term v0.0.0-20201126162022-7de9c90e9dd1/go.mod h1:bj7SfCRtBDWHUb9snDiAeCFNEtKQo2Wmx5Cou7ajbmo=
+golang.org/x/term v0.0.0-20210927222741-03fcf44c2211/go.mod h1:jbD1KX2456YbFQfuXm/mYQcufACuNUgVhRMnK/tPxf8=
 golang.org/x/text v0.3.0/go.mod h1:NqM8EUOU14njkJ3fqMW+pc6Ldnwhi/IjpwHt7yyuwOQ=
 golang.org/x/text v0.3.3/go.mod h1:5Zoc/QRtKVWzQhOtBMvqHzDpF6irO9z98xDceosuGiQ=
 golang.org/x/text v0.3.6/go.mod h1:5Zoc/QRtKVWzQhOtBMvqHzDpF6irO9z98xDceosuGiQ=
 golang.org/x/text v0.3.7 h1:olpwvP2KacW1ZWvsR7uQhoyTYvKAupfQrRGBFM352Gk=
 golang.org/x/text v0.3.7/go.mod h1:u+2+/6zg+i71rQMx5EYifcz6MCKuco9NR6JIITiCfzQ=
 golang.org/x/tools v0.0.0-20180917221912-90fa682c2a6e/go.mod h1:n7NCudcB/nEzxVGmLbDWY5pfWTLqBcC2KZ6jyYvM4mQ=
+golang.org/x/tools v0.0.0-20190114222345-bf090417da8b/go.mod h1:n7NCudcB/nEzxVGmLbDWY5pfWTLqBcC2KZ6jyYvM4mQ=
+golang.org/x/tools v0.0.0-20190226205152-f727befe758c/go.mod h1:9Yl7xja0Znq3iFh3HoIrodX9oNMXvdceNzlUR8zjMvY=
 golang.org/x/tools v0.0.0-20190311212946-11955173bddd/go.mod h1:LCzVGOaR6xXOjkQ3onu1FJEFr0SW1gC7cKk1uF8kGRs=
+golang.org/x/tools v0.0.0-20190524140312-2c0ae7006135/go.mod h1:RgjU9mgBXZiqYHBnxXauZ1Gv1EHHAz9KjViQ78xBX0Q=
 golang.org/x/tools v0.0.0-20191119224855-298f0cb1881e/go.mod h1:b+2E5dAYhXwXZwtnZ6UAqBI28+e2cm9otk0dWdXHAEo=
 golang.org/x/tools v0.1.5/go.mod h1:o0xws9oXOQQZyjljx8fwUC0k7L1pTE6eaCbjGeHmOkk=
 golang.org/x/xerrors v0.0.0-20190717185122-a985d3407aa7/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0=
@@ -116,6 +216,25 @@ golang.org/x/xerrors v0.0.0-20191011141410-1b5146add898/go.mod h1:I/5z698sn9Ka8T
 golang.org/x/xerrors v0.0.0-20191204190536-9bdfabe68543/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0=
 golang.org/x/xerrors v0.0.0-20200804184101-5ec99f83aff1 h1:go1bK/D/BFZV2I8cIQd1NKEZ+0owSTG1fDTci4IqFcE=
 golang.org/x/xerrors v0.0.0-20200804184101-5ec99f83aff1/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0=
+google.golang.org/appengine v1.1.0/go.mod h1:EbEs0AVv82hx2wNQdGPgUI5lhzA/G0D9YwlJXL52JkM=
+google.golang.org/appengine v1.4.0/go.mod h1:xpcJRLb0r/rnEns0DIKYYv+WjYCduHsrkT7/EB5XEv4=
+google.golang.org/genproto v0.0.0-20180817151627-c66870c02cf8/go.mod h1:JiN7NxoALGmiZfu7CAH4rXhgtRTLTxftemlI0sWmxmc=
+google.golang.org/genproto v0.0.0-20190819201941-24fa4b261c55/go.mod h1:DMBHOl98Agz4BDEuKkezgsaosCRResVns1a3J2ZsMNc=
+google.golang.org/genproto v0.0.0-20200526211855-cb27e3aa2013/go.mod h1:NbSheEEYHJ7i3ixzK3sjbqSGDJWnxyFXZblF3eUsNvo=
+google.golang.org/grpc v1.19.0/go.mod h1:mqu4LbDTu4XGKhr4mRzUsmM4RtVoemTSY81AxZiDr8c=
+google.golang.org/grpc v1.23.0/go.mod h1:Y5yQAOtifL1yxbo5wqy6BxZv8vAUGQwXBOALyacEbxg=
+google.golang.org/grpc v1.25.1/go.mod h1:c3i+UQWmh7LiEpx4sFZnkU36qjEYZ0imhYfXVyQciAY=
+google.golang.org/grpc v1.27.0/go.mod h1:qbnxyOmOxrQa7FizSgH+ReBfzJrCY1pSN7KXBS8abTk=
+google.golang.org/grpc v1.33.2/go.mod h1:JMHMWHQWaTccqQQlmk3MJZS+GWXOdAesneDmEnv2fbc=
+google.golang.org/protobuf v0.0.0-20200109180630-ec00e32a8dfd/go.mod h1:DFci5gLYBciE7Vtevhsrf46CRTquxDuWsQurQQe4oz8=
+google.golang.org/protobuf v0.0.0-20200221191635-4d8936d0db64/go.mod h1:kwYJMbMJ01Woi6D6+Kah6886xMZcty6N08ah7+eCXa0=
+google.golang.org/protobuf v0.0.0-20200228230310-ab0ca4ff8a60/go.mod h1:cfTl7dwQJ+fmap5saPgwCLgHXTUD7jkjRqWcaiX5VyM=
+google.golang.org/protobuf v1.20.1-0.20200309200217-e05f789c0967/go.mod h1:A+miEFZTKqfCUM6K7xSMQL9OKL/b6hQv+e19PK+JZNE=
+google.golang.org/protobuf v1.21.0/go.mod h1:47Nbq4nVaFHyn7ilMalzfO3qCViNmqZ2kzikPIcrTAo=
+google.golang.org/protobuf v1.22.0/go.mod h1:EGpADcykh3NcUnDUJcl1+ZksZNG86OlYog2l/sGQquU=
+google.golang.org/protobuf v1.23.0/go.mod h1:EGpADcykh3NcUnDUJcl1+ZksZNG86OlYog2l/sGQquU=
+google.golang.org/protobuf v1.23.1-0.20200526195155-81db48ad09cc/go.mod h1:EGpADcykh3NcUnDUJcl1+ZksZNG86OlYog2l/sGQquU=
+google.golang.org/protobuf v1.25.0/go.mod h1:9JNX74DMeImyA3h4bdi1ymwjUzf21/xIlbajtzgsN7c=
 gopkg.in/check.v1 v0.0.0-20161208181325-20d25e280405/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0=
 gopkg.in/check.v1 v1.0.0-20180628173108-788fd7840127 h1:qIbj1fsPNlZgppZ+VLlY7N33q108Sa+fhmuc+sWQYwY=
 gopkg.in/check.v1 v1.0.0-20180628173108-788fd7840127/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0=
@@ -123,9 +242,11 @@ gopkg.in/mgo.v2 v2.0.0-20190816093944-a6b53ec6cb22 h1:VpOs+IwYnYBaFnrNAeB8UUWtL3
 gopkg.in/mgo.v2 v2.0.0-20190816093944-a6b53ec6cb22/go.mod h1:yeKp02qBN3iKW1OzL3MGk2IdtZzaj7SFntXj72NppTA=
 gopkg.in/natefinch/lumberjack.v2 v2.0.0 h1:1Lc07Kr7qY4U2YPouBjpCLxpiyxIVoxqXgkXLknAOE8=
 gopkg.in/natefinch/lumberjack.v2 v2.0.0/go.mod h1:l0ndWWf7gzL7RNwBG7wST/UCcT4T24xpD6X8LsfU/+k=
-gopkg.in/olivere/elastic.v2 v2.0.61/go.mod h1:CTVyl1gckiFw1aLZYxC00g3f9jnHmhoOKcWF7W3c6n4=
+gopkg.in/yaml.v2 v2.2.8/go.mod h1:hI93XBmqTisBFMUTm0b8Fm+jr3Dg1NNxqwp+5A1VGuI=
 gopkg.in/yaml.v2 v2.4.0 h1:D8xgwECY7CYvx+Y2n4sBz93Jn9JRvxdiyyo8CTfuKaY=
 gopkg.in/yaml.v2 v2.4.0/go.mod h1:RDklbk79AGWmwhnvt/jBztapEOGDOx6ZbXqjP6csGnQ=
 gopkg.in/yaml.v3 v3.0.0-20200313102051-9f266ea9e77c/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM=
 gopkg.in/yaml.v3 v3.0.1 h1:fxVm/GzAzEWqLHuvctI91KS9hhNmmWOoWu0XTYJS7CA=
 gopkg.in/yaml.v3 v3.0.1/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM=
+honnef.co/go/tools v0.0.0-20190102054323-c2f93a96b099/go.mod h1:rf3lG4BRIbNafJWhAfAdb/ePZxsR/4RtNHQocxwk9r4=
+honnef.co/go/tools v0.0.0-20190523083050-ea95bdfd59fc/go.mod h1:rf3lG4BRIbNafJWhAfAdb/ePZxsR/4RtNHQocxwk9r4=

+ 10 - 0
proposed_project/init.go

@@ -1,6 +1,7 @@
 package main
 
 import (
+	"app.yhyue.com/data_processing/common_utils/elastic"
 	"app.yhyue.com/data_processing/common_utils/log"
 	"app.yhyue.com/data_processing/common_utils/mongodb"
 	"app.yhyue.com/data_processing/common_utils/mysqldb"
@@ -108,6 +109,14 @@ func InitMysql() {
 	MysqlTool1.Init()
 }
 
+func InitEs() {
+	Es = &elastic.Elastic{
+		S_esurl: config.Conf.DB.Es.Addr,
+		I_size:  config.Conf.DB.Es.Size,
+	}
+	Es.InitElasticSize()
+}
+
 type Pname struct {
 	Id   map[string]string
 	Lock sync.Mutex
@@ -133,6 +142,7 @@ type Project struct {
 	Owner               string   `json:"owner"`
 	ApproveCode         string   `json:"approvecode"` // 审批代码
 	ApproveNumber       string   `json:"approvenumber"`
+	ApproveDept         string   `json:"approvedept"`
 	TotalInvestment     string   `json:"total_investment"`
 	ProjectAddr         string   `json:"projectaddr"`
 	Funds               string   `json:"funds"`

+ 148 - 9
proposed_project/main.go

@@ -2,6 +2,7 @@ package main
 
 import (
 	util "app.yhyue.com/data_processing/common_utils"
+	"app.yhyue.com/data_processing/common_utils/elastic"
 	"app.yhyue.com/data_processing/common_utils/log"
 	"app.yhyue.com/data_processing/common_utils/mongodb"
 	"app.yhyue.com/data_processing/common_utils/redis"
@@ -21,6 +22,11 @@ import (
 
 var (
 	UdpClient udp.UdpClient
+
+	Es         *elastic.Elastic
+	EsBulkSize = 200
+	saveEsPool = make(chan map[string]interface{}, 5000)
+	saveEsSp   = make(chan bool, 3)
 )
 
 func main() {
@@ -33,6 +39,7 @@ func main() {
 	rootCmd.AddCommand(tidbSave())
 	rootCmd.AddCommand(tidbAddSave())
 	rootCmd.AddCommand(redisSave())
+	rootCmd.AddCommand(esSave())
 
 	if err := rootCmd.Execute(); err != nil {
 		fmt.Println("rootCmd.Execute failed", err.Error())
@@ -60,6 +67,8 @@ func project() *cobra.Command {
 		Use:   "project",
 		Short: "Start processing project data",
 		Run: func(cmd *cobra.Command, args []string) {
+			InitRule()
+
 			loadProject()
 			go updateAllQueue()
 
@@ -133,7 +142,7 @@ func projectAdd() *cobra.Command {
 			loadProject()
 			go updateAllQueue()
 
-			info, _ := MgoBid.Find("nzj_bidding", nil, `{"publishtime": -1}`, nil, true, -1, 1)
+			info, _ := MgoBid.Find("nzj_bidding", nil, `{"_id": -1}`, nil, true, -1, 1)
 			doTask(LastId, mongodb.BsonIdToSId((*info)[0]["_id"]))
 			LastId = mongodb.BsonIdToSId((*info)[0]["_id"])
 
@@ -141,7 +150,7 @@ func projectAdd() *cobra.Command {
 			cronstr := "0 */30 * * * ?" // 每30min执行一次
 			_ = crn.AddFunc(cronstr, func() {
 				if TaskSingle {
-					info, _ := MgoBid.Find("nzj_bidding", nil, `{"publishtime": -1}`, nil, true, -1, 1)
+					info, _ := MgoBid.Find("nzj_bidding", nil, `{"_id": -1}`, nil, true, -1, 1)
 					TaskSingle = false
 					doTask(LastId, mongodb.BsonIdToSId((*info)[0]["_id"]))
 					LastId = mongodb.BsonIdToSId((*info)[0]["_id"])
@@ -167,11 +176,11 @@ func tidbSave() *cobra.Command {
 		Run: func(cmd *cobra.Command, args []string) {
 			InitMysql()
 			InitArea()
-			//go SaveFunc("dwd_f_nzj_baseinfo_new", BaseField)
-			//go SaveRFunc("dwd_f_nzj_follw_record_new", RecordField)
-			//go SaveCFunc("dwd_f_nzj_contact_new", ContactField)
-			//go SaveCyFunc("dwd_f_nzj_category_tags_new", CategoryField)
-			go SaveEntFunc("dwd_f_nzj_ent", EntField)
+			go SaveFunc("dwd_f_nzj_baseinfo_new", BaseField)
+			go SaveRFunc("dwd_f_nzj_follw_record_new", RecordField)
+			go SaveCFunc("dwd_f_nzj_contact_new", ContactField)
+			go SaveCyFunc("dwd_f_nzj_category_tags_new", CategoryField)
+			go SaveEntFunc("dwd_f_nzj_ent_new", EntField)
 
 			redis.InitRedis1("ent_id=172.17.4.189:8379", 6) // name_id
 
@@ -197,7 +206,7 @@ func tidbAddSave() *cobra.Command {
 
 			redis.InitRedis1("ent_id=172.17.4.189:8379", 6) // name_id
 
-			//taskTidb_add(bson.M{"pici": bson.M{"$gt": pici}})
+			taskTidb_add(bson.M{"pici": bson.M{"$gt": pici}})
 
 			crn := cron.New()
 			cronstr := "0 */30 * * * ?" // 每30min执行一次
@@ -234,6 +243,25 @@ func redisSave() *cobra.Command {
 	return cmdClient
 }
 
+func esSave() *cobra.Command {
+	cmdClient := &cobra.Command{
+		Use:   "es-save",
+		Short: "Start processing project save to es",
+		Run: func(cmd *cobra.Command, args []string) {
+			InitMysql()
+			InitArea()
+			InitTagCode()
+			InitEs()
+			go SaveEs()
+
+			esDisp()
+			c := make(chan bool, 1)
+			<-c
+		},
+	}
+	return cmdClient
+}
+
 func processUdpMsg(act byte, data []byte, ra *net.UDPAddr) {
 	switch act {
 	case udp.OP_TYPE_DATA:
@@ -261,7 +289,7 @@ func processUdpMsg(act byte, data []byte, ra *net.UDPAddr) {
 
 func taskQ() (string, string) {
 	log.Info("taskQ", zap.String("lastid", LastId))
-	query := bson.M{"_id": bson.M{"$gt": mongodb.StringTOBsonId(LastId)}, "dataprocess": 8}
+	query := bson.M{"gtid": bson.M{"$gt": LastId}, "dataprocess": 8}
 	info, _ := MgoBid.Find("bidding_processing_ids", query, `{"_id": -1}`, nil, false, -1, 1)
 	if len(*info) > 0 {
 		newid := util.ObjToString((*info)[0]["lteid"])
@@ -338,6 +366,82 @@ func redisDisp() {
 	}
 }
 
+var EsField = []string{"_id", "projectname", "owner", "area", "city", "district", "nature_code", "ownerclass_code", "project_stage_code", "category_code", "total_investment", "lasttime", "proposed_id"}
+
+func esDisp() {
+	sess := MgoPro.GetMgoConn()
+	defer MgoPro.DestoryMongoConn(sess)
+
+	client := Es.GetEsConn()
+	defer Es.DestoryEsConn(client)
+
+	ch := make(chan bool, config.Conf.Serve.Thread)
+	wg := &sync.WaitGroup{}
+
+	query := sess.DB(config.Conf.DB.MongoP.Dbname).C(config.Conf.DB.MongoP.Coll).Find(nil).Select(SelectF).Iter()
+	count := 0
+	for tmp := make(map[string]interface{}); query.Next(tmp); count++ {
+		if count%20000 == 0 {
+			log.Info(fmt.Sprintf("current --- %d", count))
+		}
+
+		ch <- true
+		wg.Add(1)
+		go func(tmp map[string]interface{}) {
+			defer func() {
+				<-ch
+				wg.Done()
+			}()
+			save := make(map[string]interface{})
+			for _, f := range EsField {
+				if tmp[f] == nil {
+					continue
+				}
+				if f == "_id" {
+					save["proposed_id"] = mongodb.BsonIdToSId(tmp["_id"])
+					save["_id"] = mongodb.BsonIdToSId(tmp["_id"])
+				} else if f == "area" {
+					save[f] = tmp[f]
+					save["area_code"] = AreaCode[util.ObjToString(tmp["area"])]
+					if util.ObjToString(tmp["city"]) != "" {
+						save["area_city"] = tmp["city"]
+					} else {
+						save["area_city"] = tmp["area"]
+					}
+				} else if f == "lasttime" {
+					save[f] = util.Int64All(tmp[f]) * 1000
+				} else if f == "nature_code" {
+					save[f] = tmp[f]
+					save["nature"] = TagCode["nature"].(map[string]interface{})[util.ObjToString(tmp[f])]
+				} else if f == "ownerclass_code" {
+					save[f] = tmp[f]
+					save["ownerclass"] = TagCode["owner"].(map[string]interface{})[util.ObjToString(tmp[f])]
+				} else if f == "project_stage_code" {
+					save[f] = tmp[f]
+					save["project_stage"] = TagCode["project_stage"].(map[string]interface{})[util.ObjToString(tmp[f])]
+				} else if f == "category_code" {
+					save[f] = tmp[f]
+					save["category"] = TagCode["category"].(map[string]interface{})[util.ObjToString(tmp[f])]
+				} else if f == "total_investment" {
+					text := util.ObjToString(tmp[f])
+					c := ObjToMoney(text)
+					c = c / 10000
+					if c != 0 {
+						c, _ = util.FormatFloat(c, 4)
+						save[f] = c
+					}
+				} else {
+					save[f] = tmp[f]
+				}
+			}
+			saveEsPool <- save
+		}(tmp)
+		tmp = make(map[string]interface{})
+	}
+	wg.Wait()
+	log.Info(fmt.Sprintf("over --- %d", count))
+}
+
 func saveMethod() {
 	arru := make([]map[string]interface{}, saveSize)
 	indexu := 0
@@ -372,3 +476,38 @@ func saveMethod() {
 		}
 	}
 }
+
+func SaveEs() {
+	arru := make([]map[string]interface{}, EsBulkSize)
+	indexu := 0
+	for {
+		select {
+		case v := <-saveEsPool:
+			arru[indexu] = v
+			indexu++
+			if indexu == EsBulkSize {
+				saveEsSp <- true
+				go func(arru []map[string]interface{}) {
+					defer func() {
+						<-saveEsSp
+					}()
+					Es.BulkSave(config.Conf.DB.Es.IndexP, arru)
+				}(arru)
+				arru = make([]map[string]interface{}, EsBulkSize)
+				indexu = 0
+			}
+		case <-time.After(1000 * time.Millisecond):
+			if indexu > 0 {
+				saveEsSp <- true
+				go func(arru []map[string]interface{}) {
+					defer func() {
+						<-saveEsSp
+					}()
+					Es.BulkSave(config.Conf.DB.Es.IndexP, arru)
+				}(arru[:indexu])
+				arru = make([]map[string]interface{}, EsBulkSize)
+				indexu = 0
+			}
+		}
+	}
+}

+ 7 - 1
proposed_project/merge.go

@@ -17,7 +17,7 @@ import (
 
 // @Description 参与合并流程
 // @Author J 2022/10/20 13:57
-func startProjectMerge(tmp map[string]interface{}, info *Info) {
+func startProjectMerge(tmp map[string]interface{}, info *Info) string {
 	IDArr := getCompareIds(info.ProjectName, info.Site)
 	isMerge := false
 	var mergeProject *Project
@@ -37,6 +37,7 @@ func startProjectMerge(tmp map[string]interface{}, info *Info) {
 	}
 	if isMerge && mergeProject != nil {
 		updateProject(tmp, *info, mergeProject)
+		return mergeProject.Id
 	} else {
 		_, pinfo := newProject(tmp, *info)
 		AllPidMapLock.Lock()
@@ -57,6 +58,7 @@ func startProjectMerge(tmp map[string]interface{}, info *Info) {
 		AllPnMap[info.Site] = res
 		AllPnMapLock.Unlock()
 	}
+	return info.Id
 }
 
 // @Description 通过项目名称找可以与之合并的项目集合
@@ -154,6 +156,10 @@ func updateProject(tmp map[string]interface{}, info Info, pInfo *Project) {
 		pInfo.ApproveNumber = info.ApproveNumber
 		set["approvenumber"] = info.ApproveNumber
 	}
+	if pInfo.ApproveDept == "" && info.ApproveDept != "" {
+		pInfo.ApproveDept = info.ApproveDept
+		set["approvedept"] = info.ApproveDept
+	}
 	if pInfo.TotalInvestment == "" && info.TotalInvestment != "" && utf8.RuneCountInString(info.TotalInvestment) < 1000 {
 		pInfo.TotalInvestment = info.TotalInvestment
 		set["total_investment"] = info.TotalInvestment

+ 76 - 21
proposed_project/proTask.go

@@ -8,6 +8,7 @@ import (
 	"fmt"
 	"go.uber.org/zap"
 	"proposed_project/config"
+	"strings"
 	"sync"
 	"time"
 )
@@ -59,22 +60,21 @@ func doTask(gtid, lteid string) {
 		"$gt":  mongodb.StringTOBsonId(gtid),
 		"$lte": mongodb.StringTOBsonId(lteid)}}
 	f := map[string]interface{}{
-		"detail":       0,
 		"contenthtml":  0,
 		"field_source": 0,
 		"nj_record":    0,
 		"kvtext":       0,
 	}
 	log.Info("doTask", zap.Any("q", q))
-	query := sess.DB(config.Conf.DB.MongoB.Dbname).C(config.Conf.DB.MongoB.Coll).Find(q).Select(f).Sort("publishtime").Iter()
+	query := sess.DB(config.Conf.DB.MongoB.Dbname).C("nzj_bidding").Find(q).Select(f).Sort("publishtime").Iter()
 	count := 0
 	for tmp := make(map[string]interface{}); query.Next(tmp); count++ {
-		if count%2000 == 0 {
+		if count%5000 == 0 {
 			log.Info(fmt.Sprintf("current --- %d", count))
 		}
-		if util.ObjToString(tmp["toptype"]) != "拟建" {
-			continue
-		}
+		//if util.ObjToString(tmp["toptype"]) != "拟建" {
+		//	continue
+		//}
 		ch <- true
 		wg.Add(1)
 		go func(temp map[string]interface{}) {
@@ -93,7 +93,7 @@ func doTask(gtid, lteid string) {
 		tmp = make(map[string]interface{})
 	}
 	wg.Wait()
-	log.Info(fmt.Sprintf("over --- %d", count))
+	log.Info(fmt.Sprintf("over --- %d", count), zap.String("LastId: ", LastId))
 	TaskSingle = true
 }
 
@@ -113,20 +113,7 @@ func MergeTask(tmp map[string]interface{}, info *Info) {
 				startProjectMerge(tmp, info)
 			}
 		} else {
-			pid, pinfo := newProject(tmp, *info)
-			AllPidMapLock.Lock()
-			AllPidMap[info.Id] = &ID{P: pinfo}
-			AllPidMapLock.Unlock()
-			AllPnMapLock.Lock()
-			res := AllPnMap[info.ProjectName]
-			if res != nil {
-				res.Id[info.Id] = info.ProjectName
-			} else {
-				res = &Pname{
-					Id: map[string]string{info.Id: info.ProjectName},
-				}
-			}
-			AllPnMapLock.Unlock()
+			pid = startProjectMerge(tmp, info)
 			AllCodeMapLock.Lock()
 			AllCodeMap[info.ApproveCode] = pid
 			AllCodeMapLock.Unlock()
@@ -212,6 +199,7 @@ func doTask1(gtid, lteid string) {
 				<-ch
 				wg.Done()
 			}()
+			disField(temp)
 			savePool <- temp
 		}(tmp)
 		tmp = make(map[string]interface{})
@@ -220,3 +208,70 @@ func doTask1(gtid, lteid string) {
 	log.Info(fmt.Sprintf("over --- %d", count))
 	TaskSingle = true
 }
+
+func disField(tmp map[string]interface{}) {
+	njInfo := map[string]int{
+		"approvecode":        1,
+		"approvedept":        1,
+		"approvestatus":      1,
+		"approvetime":        1,
+		"approvenumber":      1,
+		"approvecontent":     1,
+		"projecttype":        1,
+		"approvecity":        1,
+		"countryprojectcode": 1,
+		"total_investment":   1,
+		"owner":              1,
+		"projectperiod":      1,
+		"project_person":     1,
+		"projectaddr":        1,
+		"project_scale":      1,
+	}
+	code := util.ObjToString(tmp["spidercode"])
+	//只处理增量的lua采集的信息
+	if !strings.Contains(code, "_njpc") {
+
+		for f := range njInfo {
+			if tmp[f] != nil {
+				njInfo[f] = 0 //值为0表示该字段已抽取,不必再更新
+			}
+		}
+
+		//projectinfo
+		if projectinfo, ok := tmp["projectinfo"].(map[string]interface{}); ok && len(projectinfo) > 0 {
+			flag := false
+			for f, n := range njInfo {
+				if n == 1 && projectinfo[f] != nil {
+					tmp[f] = projectinfo[f]
+					flag = true
+				}
+			}
+			if !flag { //嵌套信息
+				tmpTime := ""
+				tmpK := "" //记录最终取哪个map
+				for k, v := range projectinfo {
+					if result, ok := v.(map[string]interface{}); ok && len(result) > 0 && k != "attachments" {
+						approvetime := util.ObjToString(result["approvetime"])
+						if tmpTime == "" || approvetime >= tmpTime { //取最新时间信息
+							tmpTime = approvetime
+							tmpK = k
+						}
+					}
+				}
+				if tmpK != "" {
+					if resultTmp, ok := projectinfo[tmpK].(map[string]interface{}); ok && len(resultTmp) > 0 {
+						for f, n := range njInfo {
+							if n == 1 && resultTmp[f] != nil {
+								tmp[f] = resultTmp[f]
+							}
+						}
+					}
+				}
+			}
+		}
+		//buyer
+		if buyer := tmp["buyer"]; buyer != nil && tmp["owner"] == nil {
+			tmp["owner"] = buyer
+		}
+	}
+}

+ 1 - 0
proposed_project/project_tool.go

@@ -8,6 +8,7 @@ var FIELDS = []string{
 	"projectname",
 	"approvecode",
 	"approvenumber",
+	"approvedept",
 	"total_investment",
 	"funds",
 	"owner",

+ 163 - 128
proposed_project/tidbTask.go

@@ -6,6 +6,7 @@ import (
 	"app.yhyue.com/data_processing/common_utils/mongodb"
 	"app.yhyue.com/data_processing/common_utils/redis"
 	"fmt"
+	"go.mongodb.org/mongo-driver/bson"
 	"go.uber.org/zap"
 	"math/rand"
 	"proposed_project/config"
@@ -28,15 +29,17 @@ var (
 	saveEntPool  = make(chan map[string]interface{}, 5000)
 	saveEntSp    = make(chan bool, 1)
 
-	BaseField = []string{"lasttime", "firsttime", "proposed_number", "proposed_id", "follow_num", "title", "projectname", "approvecode",
+	BaseField = []string{"lasttime", "firsttime", "proposed_number", "proposed_id", "follow_num", "title", "projectname", "approvecode", "approvedept",
 		"approvenumber", "project_stage_code", "total_investment", "funds", "owner", "name_id", "ownerclass_code", "projecttype_code", "projectaddr",
 		"projectperiod", "project_startdate", "project_completedate", "industry_code", "approvestatus", "project_scale",
 		"category_code", "nature_code", "construction_area", "floor_area", "area_code", "city_code", "createtime"}
 	RecordField   = []string{"proposed_id", "infoid", "follow_num", "project_stage_code", "title", "project_scale", "publishtime", "jybxhref", "createtime"}
 	ContactField  = []string{"proposed_id", "infoid", "follow_num", "name_id", "name", "contact_name", "contact_tel", "contact_addr", "createtime"}
 	CategoryField = []string{"proposed_id", "labelcode", "labelvalues", "labelweight", "createtime"}
-	EntField      = []string{"proposed_id", "name_id", "name", "area_code", "city_code", "createtime"}
-	AreaCode      = make(map[string]string, 5000)
+	EntField      = []string{"proposed_id", "name_id", "name", "area_code", "city_code", "address", "createtime", "identity_type"}
+
+	AreaCode = make(map[string]string, 5000)
+	TagCode  = make(map[string]interface{}, 100)
 )
 
 func InitArea() {
@@ -55,6 +58,30 @@ func InitArea() {
 	log.Info("InitField", zap.Int("AreaCode", len(AreaCode)))
 }
 
+func InitTagCode() {
+	info, _ := MgoBid.Find("nzj_rule", nil, nil, bson.M{"label_name": 1, "label": 1, "code": 1}, false, -1, -1)
+	for _, m := range *info {
+		lname := util.ObjToString(m["label_name"])
+		lb := util.ObjToString(m["label"])
+		code := util.ObjToString(m["code"])
+		if lname == "sub_category" || lname == "top_category" {
+			lname = "category"
+		}
+		if TagCode[lname] != nil {
+			m1 := TagCode[lname].(map[string]interface{})
+			m1[code] = lb
+			TagCode[lname] = m1
+		} else {
+			m1 := make(map[string]interface{})
+			m1[code] = lb
+			TagCode[lname] = m1
+		}
+	}
+	TagCode["nature"].(map[string]interface{})["00"] = "其它"
+	TagCode["project_stage"].(map[string]interface{})["00"] = "其它"
+	log.Info("InitTagCode", zap.Any("TagCode", TagCode))
+}
+
 func taskTidb(q map[string]interface{}) {
 	sess := MgoPro.GetMgoConn()
 	defer MgoPro.DestoryMongoConn(sess)
@@ -83,85 +110,85 @@ func taskTidb(q map[string]interface{}) {
 				<-ch
 				wg.Done()
 			}()
-			//saveM := make(map[string]interface{})
-			//for _, f := range BaseField {
-			//	if f == "lasttime" || f == "firsttime" {
-			//		if t := util.Int64All(tmp[f]); t > 0 {
-			//			saveM[f] = util.FormatDateByInt64(&t, util.Date_Full_Layout)
-			//		}
-			//	} else if f == "proposed_id" {
-			//		saveM[f] = mongodb.BsonIdToSId(tmp["_id"])
-			//	} else if f == "area_code" {
-			//		if tmp["area"] != nil {
-			//			saveM[f] = AreaCode[util.ObjToString(tmp["area"])]
-			//		}
-			//	} else if f == "city_code" {
-			//		if tmp["area"] != nil && tmp["city"] != nil {
-			//			c := util.ObjToString(tmp["area"]) + "," + util.ObjToString(tmp["city"])
-			//			saveM[f] = AreaCode[c]
-			//		}
-			//	} else if f == "owner" {
-			//		if v := util.ObjToString(tmp[f]); v != "" {
-			//			if utf8.RuneCountInString(v) < 100 {
-			//				saveM[f] = v
-			//			}
-			//		}
-			//	} else if f == "name_id" {
-			//		if b := util.ObjToString(tmp["owner"]); b != "" {
-			//			if eid := redis.GetStr("ent_id", b); eid != "" {
-			//				saveM["name_id"] = strings.Split(eid, "_")[0]
-			//			}
-			//		}
-			//	} else if f == "lasttime" || f == "firsttime" || f == "project_startdate" || f == "project_completedate" {
-			//		if tmp[f] != nil && util.IntAll(tmp[f]) > 0 {
-			//			t := util.Int64All(tmp[f])
-			//			saveM[f] = util.FormatDateByInt64(&t, util.Date_Full_Layout)
-			//		}
-			//	} else if f == "createtime" {
-			//		saveM[f] = time.Now().Format(util.Date_Full_Layout)
-			//	} else if f == "total_investment" {
-			//		text := util.ObjToString(tmp[f])
-			//		capital := ObjToMoney(text)
-			//		capital = capital / 10000
-			//		if capital != 0 {
-			//			capital, _ = util.FormatFloat(capital, 6)
-			//			saveM[f] = capital
-			//		}
-			//	} else if f == "approvestatus" {
-			//		if util.ObjToString(tmp[f]) != "" && utf8.RuneCountInString(util.ObjToString(tmp[f])) < 8 {
-			//			saveM[f] = tmp[f]
-			//		}
-			//	} else if f == "proposed_number" {
-			//		if tmp[f] == nil {
-			//			now := time.Now().Unix()
-			//			st := util.FormatDateByInt64(&now, util.Date_yyyyMMdd)
-			//			parseSt := strconv.FormatInt(util.Int64All(st), 8)                                       // 转8进制
-			//			rd := fmt.Sprintf("%04v", rand.New(rand.NewSource(time.Now().UnixNano())).Int63n(10000)) // 4位随机数
-			//			saveM[f] = fmt.Sprintf("NZJ%s%s", parseSt, rd)
-			//		} else {
-			//			saveM[f] = tmp[f]
-			//		}
-			//	} else if f == "approvecode" {
-			//		if util.ObjToString(tmp[f]) != "" && utf8.RuneCountInString(util.ObjToString(tmp[f])) < 200 {
-			//			saveM[f] = tmp[f]
-			//		}
-			//	} else if f == "floor_area" {
-			//		if util.ObjToString(tmp[f]) != "" && utf8.RuneCountInString(util.ObjToString(tmp[f])) < 255 {
-			//			saveM[f] = tmp[f]
-			//		}
-			//	} else {
-			//		if tmp[f] != nil {
-			//			saveM[f] = tmp[f]
-			//		}
-			//	}
-			//}
-			//saveBasePool <- saveM
-			//saveCy := make(map[string]interface{})
-			//saveCy["proposed_id"] = mongodb.BsonIdToSId(tmp["_id"])
-			//saveCy["labelcode"] = "category_code"
-			//saveCy["labelvalues"] = util.ObjToString(tmp["category_code"])
-			//saveCy["createtime"] = time.Now().Format(util.Date_Full_Layout)
-			//saveCyPool <- saveCy
+			saveM := make(map[string]interface{})
+			for _, f := range BaseField {
+				if f == "lasttime" || f == "firsttime" {
+					if t := util.Int64All(tmp[f]); t > 0 {
+						saveM[f] = util.FormatDateByInt64(&t, util.Date_Full_Layout)
+					}
+				} else if f == "proposed_id" {
+					saveM[f] = mongodb.BsonIdToSId(tmp["_id"])
+				} else if f == "area_code" {
+					if tmp["area"] != nil {
+						saveM[f] = AreaCode[util.ObjToString(tmp["area"])]
+					}
+				} else if f == "city_code" {
+					if tmp["area"] != nil && tmp["city"] != nil {
+						c := util.ObjToString(tmp["area"]) + "," + util.ObjToString(tmp["city"])
+						saveM[f] = AreaCode[c]
+					}
+				} else if f == "owner" {
+					if v := util.ObjToString(tmp[f]); v != "" {
+						if utf8.RuneCountInString(v) < 100 {
+							saveM[f] = v
+						}
+					}
+				} else if f == "name_id" {
+					if b := util.ObjToString(tmp["owner"]); b != "" {
+						if eid := redis.GetStr("ent_id", b); eid != "" {
+							saveM["name_id"] = strings.Split(eid, "_")[0]
+						}
+					}
+				} else if f == "lasttime" || f == "firsttime" || f == "project_startdate" || f == "project_completedate" {
+					if tmp[f] != nil && util.IntAll(tmp[f]) > 0 {
+						t := util.Int64All(tmp[f])
+						saveM[f] = util.FormatDateByInt64(&t, util.Date_Full_Layout)
+					}
+				} else if f == "createtime" {
+					saveM[f] = time.Now().Format(util.Date_Full_Layout)
+				} else if f == "total_investment" {
+					text := util.ObjToString(tmp[f])
+					capital := ObjToMoney(text)
+					capital = capital / 10000
+					if capital != 0 {
+						capital, _ = util.FormatFloat(capital, 6)
+						saveM[f] = capital
+					}
+				} else if f == "approvestatus" {
+					if util.ObjToString(tmp[f]) != "" && utf8.RuneCountInString(util.ObjToString(tmp[f])) < 8 {
+						saveM[f] = tmp[f]
+					}
+				} else if f == "proposed_number" {
+					if tmp[f] == nil {
+						now := time.Now().Unix()
+						st := util.FormatDateByInt64(&now, util.Date_yyyyMMdd)
+						parseSt := strconv.FormatInt(util.Int64All(st), 8)                                       // 转8进制
+						rd := fmt.Sprintf("%04v", rand.New(rand.NewSource(time.Now().UnixNano())).Int63n(10000)) // 4位随机数
+						saveM[f] = fmt.Sprintf("NZJ%s%s", parseSt, rd)
+					} else {
+						saveM[f] = tmp[f]
+					}
+				} else if f == "approvecode" {
+					if util.ObjToString(tmp[f]) != "" && utf8.RuneCountInString(util.ObjToString(tmp[f])) < 200 {
+						saveM[f] = tmp[f]
+					}
+				} else if f == "floor_area" {
+					if util.ObjToString(tmp[f]) != "" && utf8.RuneCountInString(util.ObjToString(tmp[f])) < 255 {
+						saveM[f] = tmp[f]
+					}
+				} else {
+					if tmp[f] != nil {
+						saveM[f] = tmp[f]
+					}
+				}
+			}
+			saveBasePool <- saveM
+			saveCy := make(map[string]interface{})
+			saveCy["proposed_id"] = mongodb.BsonIdToSId(tmp["_id"])
+			saveCy["labelcode"] = "category_code"
+			saveCy["labelvalues"] = util.ObjToString(tmp["category_code"])
+			saveCy["createtime"] = time.Now().Format(util.Date_Full_Layout)
+			saveCyPool <- saveCy
 			if ow := util.ObjToString(tmp["owner"]); ow != "" {
 				saveEnt := make(map[string]interface{})
 				saveEnt["proposed_id"] = mongodb.BsonIdToSId(tmp["_id"])
@@ -175,53 +202,57 @@ func taskTidb(q map[string]interface{}) {
 					} else if len(arr) == 3 {
 						saveEnt["city_code"] = arr[2]
 					}
+					info := MysqlTool1.Find("dws_f_ent_baseinfo", bson.M{"name_id": arr[0]}, "address", "", -1, -1)
+					if info != nil && len(*info) > 0 {
+						saveEnt["address"] = (*info)[0]["address"]
+					}
 				}
-				saveEnt["identify_type"] = 1
+				saveEnt["identity_type"] = 1
 				saveEnt["area_code"] = AreaCode[util.ObjToString(tmp["area"])]
 				saveEntPool <- saveEnt
 			}
 
-			//for _, v := range tmp["list"].([]interface{}) {
-			//	saveRc := make(map[string]interface{})
-			//	v1 := v.(map[string]interface{})
-			//	saveRc["proposed_id"] = mongodb.BsonIdToSId(tmp["_id"])
-			//	infoid := util.ObjToString(v1["infoid"])
-			//	saveRc["infoid"] = infoid
-			//	saveRc["jybxhref"] = fmt.Sprintf(config.Conf.Serve.JyHref, util.CommonEncodeArticle("content", infoid))
-			//	saveRc["follow_num"] = v1["follow_num"]
-			//	saveRc["project_scale"] = util.ObjToString(v1["project_scale"])
-			//	saveRc["project_stage_code"] = util.ObjToString(v1["project_stage_code"])
-			//	saveRc["title"] = util.ObjToString(v1["title"])
-			//	if t := util.Int64All(v1["publishtime"]); t > 0 {
-			//		saveRc["publishtime"] = util.FormatDateByInt64(&t, util.Date_Full_Layout)
-			//	}
-			//	saveRc["createtime"] = time.Now().Format(util.Date_Full_Layout)
-			//	saveRcPool <- saveRc
-			//
-			//	//if util.ObjToString(v1["project_person"]) != "" || util.ObjToString(v1["project_phone"]) != "" {
-			//	//	saveCt := make(map[string]interface{})
-			//	//	saveCt["proposed_id"] = mongodb.BsonIdToSId(tmp["_id"])
-			//	//	saveCt["infoid"] = infoid
-			//	//	saveCt["follow_num"] = tmp["follow_num"]
-			//	//	if b := util.ObjToString(tmp["owner"]); b != "" {
-			//	//		saveCt["name"] = util.ObjToString(tmp["owner"])
-			//	//		if eid := redis.GetStr("ent_id", b); eid != "" {
-			//	//			saveCt["name_id"] = strings.Split(eid, "_")[0]
-			//	//		}
-			//	//	}
-			//	//	if p := util.ObjToString(v1["project_person"]); p != "" {
-			//	//		saveCt["contact_name"] = p
-			//	//	}
-			//	//	if p := util.ObjToString(v1["project_phone"]); p != "" {
-			//	//		saveCt["contact_tel"] = p
-			//	//	}
-			//	//	if p := util.ObjToString(v1["projectaddr"]); p != "" {
-			//	//		saveCt["contact_addr"] = p
-			//	//	}
-			//	//	saveCt["createtime"] = time.Now().Format(util.Date_Full_Layout)
-			//	//	saveCtPool <- saveCt
-			//	//}
-			//}
+			for _, v := range tmp["list"].([]interface{}) {
+				saveRc := make(map[string]interface{})
+				v1 := v.(map[string]interface{})
+				saveRc["proposed_id"] = mongodb.BsonIdToSId(tmp["_id"])
+				infoid := util.ObjToString(v1["infoid"])
+				saveRc["infoid"] = infoid
+				saveRc["jybxhref"] = fmt.Sprintf(config.Conf.Serve.JyHref, util.CommonEncodeArticle("content", infoid))
+				saveRc["follow_num"] = v1["follow_num"]
+				saveRc["project_scale"] = util.ObjToString(v1["project_scale"])
+				saveRc["project_stage_code"] = util.ObjToString(v1["project_stage_code"])
+				saveRc["title"] = util.ObjToString(v1["title"])
+				if t := util.Int64All(v1["publishtime"]); t > 0 {
+					saveRc["publishtime"] = util.FormatDateByInt64(&t, util.Date_Full_Layout)
+				}
+				saveRc["createtime"] = time.Now().Format(util.Date_Full_Layout)
+				saveRcPool <- saveRc
+
+				if util.ObjToString(v1["project_person"]) != "" || util.ObjToString(v1["project_phone"]) != "" {
+					saveCt := make(map[string]interface{})
+					saveCt["proposed_id"] = mongodb.BsonIdToSId(tmp["_id"])
+					saveCt["infoid"] = infoid
+					saveCt["follow_num"] = tmp["follow_num"]
+					if b := util.ObjToString(tmp["owner"]); b != "" {
+						saveCt["name"] = util.ObjToString(tmp["owner"])
+						if eid := redis.GetStr("ent_id", b); eid != "" {
+							saveCt["name_id"] = strings.Split(eid, "_")[0]
+						}
+					}
+					if p := util.ObjToString(v1["project_person"]); p != "" {
+						saveCt["contact_name"] = p
+					}
+					if p := util.ObjToString(v1["project_phone"]); p != "" {
+						saveCt["contact_tel"] = p
+					}
+					if p := util.ObjToString(v1["projectaddr"]); p != "" {
+						saveCt["contact_addr"] = p
+					}
+					saveCt["createtime"] = time.Now().Format(util.Date_Full_Layout)
+					saveCtPool <- saveCt
+				}
+			}
 		}(tmp)
 		tmp = make(map[string]interface{})
 	}
@@ -235,9 +266,9 @@ func taskTidb_add(q map[string]interface{}) {
 
 	ch := make(chan bool, config.Conf.Serve.Thread)
 	wg := &sync.WaitGroup{}
-	var query *mongodb.MgoIter
-	query = sess.DB(config.Conf.DB.MongoP.Dbname).C(config.Conf.Serve.ProColl).Find(q).Select(SelectF).Iter()
 
+	log.Info("taskTidb_add", zap.Any("q: ", q))
+	query := sess.DB(config.Conf.DB.MongoP.Dbname).C(config.Conf.Serve.ProColl).Find(q).Select(nil).Iter()
 	count := 0
 	for tmp := make(map[string]interface{}); query.Next(tmp); count++ {
 		if count%200 == 0 {
@@ -249,7 +280,7 @@ func taskTidb_add(q map[string]interface{}) {
 		ch <- true
 		wg.Add(1)
 		go func(tmp map[string]interface{}) {
-			defer func() {
+			go func() {
 				<-ch
 				wg.Done()
 			}()
@@ -371,8 +402,12 @@ func taskB(tmp map[string]interface{}) {
 				} else if len(arr) == 3 {
 					saveEnt["city_code"] = arr[2]
 				}
+				info := MysqlTool1.Find("dws_f_ent_baseinfo", bson.M{"name_id": arr[0]}, "address", "", -1, -1)
+				if info != nil && len(*info) > 0 {
+					saveEnt["address"] = (*info)[0]["address"]
+				}
 			}
-			saveEnt["identify_type"] = 1
+			saveEnt["identity_type"] = 1
 			saveEnt["area_code"] = AreaCode[util.ObjToString(tmp["area"])]
 			MysqlTool.Insert("dwd_f_nzj_ent", saveEnt)
 		}