forked from DeepInsight-AI/DeepBI
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathubuntu_install.sh
executable file
·261 lines (253 loc) · 8.37 KB
/
ubuntu_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 "begin"
line
# check system
if [ "$(lsb_release -si)" = "Ubuntu" ] && [ "$(lsb_release -rs | cut -d. -f1)" -ge 16 ]; then
echo "System check ok!"
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 "check python ok!"
else
echo "need python 3.8+"
fi
else
echo "need python3.8+"
# shellcheck disable=SC2162
read -p "auto install 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 has installed"
# shellcheck disable=SC1073
# shellcheck disable=SC1049
if systemctl is-active --quiet redis; then
echo "redis is ok"
else
echo "start redis.. "
sudo service redis-server start
fi
else
# shellcheck disable=SC2162
read -p "auto install redis ?(Y/N): " confirm
if [[ $confirm == "Y" || $confirm == "y" ]]; then
sudo apt update
echo "redis install ......"
sudo apt-get -y install redis-server
echo "start 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 "auto install postgresql16 ?(Y/N): " confirm
if [[ $confirm == "Y" || $confirm == "y" ]]; then
echo "begin install postgresql"
echo "set postgresql source "
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 "start postgresql"
sudo service postgresql start
echo "you can run 'sudo -i -u postgres' manage database "
else
echo "need postgresql"
exit 1
fi
else
echo "you have installed postgresql"
fi
echo "start postgresql"
sudo service postgresql start
echo "create database deepbi"
if sudo -u postgres psql -lqt | cut -d \| -f 1 | grep -qw deepbi; then
echo "Database 'deepbi' already exists."
else
sudo -u postgres psql -c "CREATE DATABASE deepbi;"
echo "Database 'deepbi' created."
fi
# shellcheck disable=SC2006
if sudo -u postgres psql -tAc "SELECT 1 FROM pg_roles WHERE rolname='deepbi'" | grep -q 1; then
echo "User 'deepbi' created."
else
sudo su postgres -c "`printf 'psql -c "create user deepbi password %s;"' "'deepbi_8338'"`"
fi
echo "change database owner"
sudo -u postgres psql -c "ALTER DATABASE deepbi OWNER TO deepbi;"
echo "Setting user and database can connect"
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 "install sys extends"
# 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
line
echo "init virtual vevn"
pip install virtualenv
echo "create venv"
virtualenv venv -p python3
echo "activate venv"
source venv/bin/activate
line
# echo "set pip config"
# pip config set global.index-url https://pypi.tuna.tsinghua.edu.cn/simple
pip install --upgrade pip
line
echo "need python require"
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 configuration file does not exist, please check /usr/include/mysql/my_config.h exsist or not "
exit 1
fi
fi
echo "make .env config file"
#
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 "You local ip as fellows:"
echo "$ip_addresses" | tr ' ' '\n'
# let user select ip
echo "Please select a ip for your server, you can change it at .env file:"
while true; do
# shellcheck disable=SC2162
read -p "Please input your ip: " ip
if [[ $ip == "" ]]; then
echo "Ip mast input"
else
# shellcheck disable=SC2162
read -p "You input this: $ip ,Are you sure?(Y/N): " confirm
if [[ $confirm == "Y" || $confirm == "y" ]]; then
echo "IP :$ip"
break
fi
fi
done
# shellcheck disable=SC2162
read -p "We need server port 8338 8339 8340,is that ports not use?(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:[email protected]\/deepbi\"/g")
# replace redis
# shellcheck disable=SC2001
env_content=$(echo "$env_content" | sed "s/# DEEPBI_REDIS_URL/DEEPBI_REDIS_URL/g")
# replace ai port server
# shellcheck disable=SC2001
env_content=$(echo "$env_content" | sed "s/AI_WEB_PORT/$ai_web_port/g")
# replace language
# shellcheck disable=SC2001
env_content=$(echo "$env_content" | sed "s/LANGTYPE/EN/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
echo "Rename files "
rm -rf ./client/dist
cp -R ./client/dist_source ./client/dist
echo "Replace ip port"
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
# copy language
rm -rf ./client/app/Language.CN.js
cp ./client/app/Language_EN.js ./client/app/Language.CN.js
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 "修复 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
echo "start server"
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 "You can visit http://$ip:$web_port"
echo "--------------------------------"