-
Notifications
You must be signed in to change notification settings - Fork 414
/
ubuntu_CN_install.sh
executable file
·262 lines (253 loc) · 8.6 KB
/
ubuntu_CN_install.sh
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
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
#!/bin/bash
set -e
export LANG=en_US.UTF-8
function line() {
line=""
for (( i=1; i<=30; i++ )); do
line="$line-"
done
echo "$line"
}
echo "开始"
line
# check system
if [ "$(lsb_release -si)" = "Ubuntu" ] && [ "$(lsb_release -rs | cut -d. -f1)" -ge 16 ]; then
echo "系统检查完毕"
else
exit 1
fi
# check python
if command -v python3 &>/dev/null; then
python_version=$(python3 -c 'import sys; print(".".join(map(str, sys.version_info[:3])))')
if [ "$(echo "$python_version 3.8" | awk '{print ($1 >= $2)}')" -eq 1 ]; then
echo "python 版本检查完毕"
else
echo "需要安装python 3.8+"
fi
else
echo "需要安装 python3.8+"
# shellcheck disable=SC2162
read -p "即将自动安装 python3.8 ?(Y/N): " confirm
if [[ $confirm == "Y" || $confirm == "y" ]]; then
sudo apt update
sudo apt install python3.8
else
exit 1
fi
fi
line
# check redis and install
# shellcheck disable=SC1009
if command -v redis-server &>/dev/null; then
echo "Redis 已经安装 ,如果需要设置密码,修改安装后的.env"
# shellcheck disable=SC1073
# shellcheck disable=SC1049
if systemctl is-active --quiet redis; then
echo "redis 检查完毕"
else
echo "启动 redis.. "
sudo service redis-server start
fi
else
# shellcheck disable=SC2162
read -p "自动安装redis ?(Y/N): " confirm
if [[ $confirm == "Y" || $confirm == "y" ]]; then
sudo apt update
echo "正在安装redis ......"
sudo apt-get -y install redis-server
echo "启动 redis.. "
sudo service redis-server start
sudo systemctl enable redis-server
else
exit 1
fi
fi
line
# install postgresql
# shellcheck disable=SC1009
if ! command -v psql &> /dev/null; then
# shellcheck disable=SC2162
read -p "自动安装 postgresql16 ?(Y/N): " confirm
if [[ $confirm == "Y" || $confirm == "y" ]]; then
echo "开始安装 postgresql"
echo "设置 postgresql 源 "
sudo wget --quiet -O - https://www.postgresql.org/media/keys/ACCC4CF8.asc | sudo apt-key add -
echo "deb http://apt.postgresql.org/pub/repos/apt/ $(lsb_release -cs)-pgdg main" | sudo tee /etc/apt/sources.list.d/pgdg.list
sudo apt-get update
sudo apt-get install postgresql-16 -y
echo "启动 postgresql"
sudo service postgresql start
echo "你可以通过 'sudo -i -u postgres' manage database 管理数据库 "
else
echo "需要安装 数据库 postgresql"
exit 1
fi
else
echo "你已经安装了 postgresql"
fi
echo "启动 postgresql"
sudo service postgresql start
echo "创建数据库 deepbi"
if sudo -u postgres psql -lqt | cut -d \| -f 1 | grep -qw deepbi; then
echo "数据库 'deepbi' 已经存在."
else
sudo -u postgres psql -c "CREATE DATABASE deepbi;"
echo "数据库 'deepbi' 创建完毕."
fi
# shellcheck disable=SC2006
if sudo -u postgres psql -tAc "SELECT 1 FROM pg_roles WHERE rolname='deepbi'" | grep -q 1; then
echo "用户 'deepbi' 已经存在."
else
echo "创建用户 'deepbi' "
sudo su postgres -c "`printf 'psql -c "create user deepbi password %s;"' "'deepbi_8338'"`"
fi
echo "修改数据库 database 所有者"
sudo -u postgres psql -c "ALTER DATABASE deepbi OWNER TO deepbi;"
echo "设置用户连接"
sudo sh -c "sed -i '/^#\s*TYPE/ahost deepbi deepbi 127.0.0.1/32 md5' /etc/postgresql/16/main/pg_hba.conf && service postgresql restart "
line
echo "安装系统扩展"
# shellcheck disable=SC1004
sudo dpkg --remove-architecture i386
sudo apt-get update
sudo apt-get install -y python3-pip \
libaio1 libaio-dev alien curl gnupg build-essential pwgen libffi-dev git-core wget \
libpq-dev g++ unixodbc-dev xmlsec1 libssl-dev default-libmysqlclient-dev freetds-dev \
libsasl2-dev unzip libsasl2-modules-gssapi-mit libmysqlclient-dev
line
echo "安装虚拟环境扩展 virtual vevn"
pip install virtualenv
echo "创建虚拟环境 venv"
virtualenv venv -p python3
echo "激活虚拟环境 venv"
source venv/bin/activate
line
echo "设置国内源 pip config"
pip config set global.index-url https://pypi.tuna.tsinghua.edu.cn/simple
pip install --upgrade pip
line
echo "安装 python 扩展"
pip install -r vrequment.txt
line
# check mysql config file
if [ -f /usr/include/mysql/my_config.h ]; then
echo "mysql config file is ok"
else
if [ -f /usr/include/mysql/mysql.h ]; then
sudo ln -s /usr/include/mysql/mysql.h /usr/include/mysql/my_config.h
else
echo "mysql config file is not ok, please check /usr/include/mysql/my_config.h exsist or not "
exit 1
fi
fi
line
if [ -f .env ]; then
rm .env
fi
# get local ip
ip_addresses=$(ifconfig | grep -Eo 'inet (addr:)?([0-9]*\.){3}[0-9]*' | grep -Eo '([0-9]*\.){3}[0-9]*')
# print ip for user to select the ip
echo "本地ip地址如下:"
echo "$ip_addresses" | tr ' ' '\n'
# let user select ip
echo "选择一个你可以访问的地址,最好是局域网内地址 比如 192.168.x.x"
while true; do
# shellcheck disable=SC2162
read -p "请输入你的选择 ip: " ip
if [[ $ip == "" ]]; then
echo "Ip 必须输入"
else
# shellcheck disable=SC2162
read -p "你的输入是: $ip ,确定么?(Y/N): " confirm
if [[ $confirm == "Y" || $confirm == "y" ]]; then
echo "IP :$ip"
break
fi
fi
done
# shellcheck disable=SC2162
read -p "我们需要端口 8338 8339 8340,确定它们没有使用?(Y/N): " confirm
if [[ $confirm == "N" || $confirm == "n" ]]; then
exit 1
fi
# get web port
# shellcheck disable=SC2162
web_port=8338
# get socket port
# shellcheck disable=SC2162
socket_port=8339
# ai server port
# shellcheck disable=SC2162
ai_web_port=8340
# get env_template content
env_content=$(cat .env.template)
# replace postgresql
# shellcheck disable=SC2001
env_content=$(echo "$env_content" | sed "s/# DEEPBI_DATABASE_URL=\"postgresql:\/\/user:pwd@ip\/database\"/DEEPBI_DATABASE_URL=\"postgresql:\/\/deepbi:deepbi_8338@127.0.0.1\/deepbi\"/g")
# replace redis
# shellcheck disable=SC2001
env_content=$(echo "$env_content" | sed "s/# DEEPBI_REDIS_URL/DEEPBI_REDIS_URL/g")
# replace language
# shellcheck disable=SC2001
env_content=$(echo "$env_content" | sed "s/LANGTYPE/CN/g")
# replace ai port server
# shellcheck disable=SC2001
env_content=$(echo "$env_content" | sed "s/AI_WEB_PORT/$ai_web_port/g")
# replace web port
# shellcheck disable=SC2001
env_content=$(echo "$env_content" | sed "s/WEB_PORT/$web_port/g")
# replace language
# shellcheck disable=SC2001
env_content=$(echo "$env_content" | sed "s/SOCKET_PORT/$socket_port/g")
# replace ip
# shellcheck disable=SC2001
env_content=$(echo "$env_content" | sed "s/IP/$ip/g")
# replace sec_key
sec_key=$(openssl rand -hex 16)
# shellcheck disable=SC2001
env_content=$(echo "$env_content" | sed "s/SEC_KEY/$sec_key/g")
# set user upload dir
# save .env file
echo "$env_content" > .env
root=$(pwd)
echo "DATA_SOURCE_FILE_DIR=$root/user_upload_files" >> .env
line
echo "重命名前端文件 "
rm -rf ./client/dist
cp -R ./client/dist_source ./client/dist
# replace front file ip
echo "替换前端 IP 地址"
sed -i "s|192.168.5.165:8339|$ip:$socket_port|g" ./client/dist/vendors~app.js
sed -i "s|192.168.5.165:8339|$ip:$socket_port|g" ./client/dist/app.js
line
echo "激活环境"
source venv/bin/activate
line
python_version=$(python3 -c 'import sys; print(".".join(map(str, sys.version_info[:3])))')
if [[ "$python_version" == "3.8."* ]]; then
echo "fix python3.8 bug"
sed -i 's/from importlib_resources import path/from importlib.resources import path/g' ./venv/lib/python3.8/site-packages/saml2/sigver.py &&
sed -i 's/from importlib_resources import path/from importlib.resources import path/g' ./venv/lib/python3.8/site-packages/saml2/xml/schema/__init__.py
line
fi
echo "init database "
./bin/run ./manage.py database create_tables
line
# start server backend
if [ ! -d "log" ]; then
mkdir log
fi
./bin/run ./manage.py runserver -h0.0.0.0 -p "$web_port" >log/web.log 2>&1 &
echo $! >./user_upload_files/.web.pid.txt
./bin/run ./manage.py rq scheduler >log/scheduler.log 2>&1 &
echo $! >./user_upload_files/.scheduler.pid.txt
./bin/run ./manage.py rq worker >log/worker.log 2>&1 &
echo $! >./user_upload_files/.worker.pid.txt
./bin/run ./manage.py run_ai >log/ai.log 2>&1 &
echo $! >./user_upload_files/.ai.pid.txt
./bin/run ./manage.py run_ai_api >log/run_ai_api.log 2>&1 &
echo $! >./user_upload_files/.run_ai_api.pid.txt
echo "--------------------------------"
echo "启动成功,你可以访问 http://$ip:$web_port"
echo "--------------------------------"
echo "谢谢,如果有问题,可以给我们提issue "