-
Notifications
You must be signed in to change notification settings - Fork 6
/
Copy pathconfig.py
129 lines (88 loc) · 2.52 KB
/
config.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
# coding=utf8
import os
import redis
os.chdir(os.path.split(os.path.abspath(__file__))[0])
import logging
from UserAgent import user_agent_list
# 日志部分
logger = logging.getLogger('main')
logger.setLevel(logging.INFO)
handler = logging.FileHandler('./log/system.log')
fmt = logging.Formatter('%(asctime)s - %(levelname)s - %(message)s')
handler.setFormatter(fmt)
logger.addHandler(handler)
# redis模块
# 在导入config之处,就已经实例化并链接了redis了
host = 'localhost'
port = 6379
db = 1
def connect_redis():
"""链接到redis"""
re = None
try:
re = redis.StrictRedis(host=host, port=port, db=5)
except Exception as e:
logger.warning('请启动\tredis\t服务, {0}'.format(e))
return re
redis_cli = connect_redis()
# 消息队列名称
# mark_que
mark_que = 'mark'
task_que = 'taskque'
task_que_fb = 'taskquefb'
# # session请求队列
# ssn_req = 'ssnreq'
#
# # session回复队列
# ssn_rep = 'ssnrep'
#
# # session状态队列
# ssn_status = 'ssnsts'
#
# # seed请求队列
# sed_req = 'sedreq'
#
# # 持久化队列
# psm_que = 'psmque'
# session-slave
ssn_2_slv = 'ssnp'
# slave-session
slv_2_ssn = 'ssnq'
# seed-slave
sed_2_slv = 'taskque'
# slave-seed
slv_2_sed = 'sedq'
# 持久化队列
slv_2_psm = 'psmque'
# 消息队列引用
# [LoginHander.py]
home_page_url = "http://www.guazi.com"
log_in_xpath = {
'adv2': '/html/body/div[2]/div[2]/div/div/div[2]/a[1]',
'log_btn': '//*[@id="js-login"]',
'phone_number': '/html/body/div[3]/div[2]/form/ul/li[1]/input',
'captcha_btn': '/html/body/div[3]/div[2]/form/ul/li[2]/button',
'captcha_input': '/html/body/div[3]/div[2]/form/ul/li[2]/input',
'commit_btn': '/html/body/div[3]/div[2]/form/button',
}
user_info_file = './DB/user_info.txt'
# 种子部分
offset_file = './DB/seed_offset.txt'
seeds_store = './DB/seeds_store.txt'
# [spiderHandler]
headers = {
"Accept": "text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8",
"Accept-Encoding": "gzip, deflate, br",
"Host": "www.guazi.com",
"Referer": "https://www.guazi.com",
"Upgrade-Insecure-Requests": "1",
"User-Agent": "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_13_5) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/67.0.3396.99 Safari/537.36"
}
ua_list = user_agent_list
request_retry = 2
# [持久化部分]
data_file = './DB/guazi_data.txt'
token = './DB/guazi_token.txt'
hdfs_path = '/user/spider/car_price/guazi/guazi_data.txt'
hdfs_ip = '47.98.32.168:50070'
user_name = 'spider'