12 Commits

Author SHA1 Message Date
b7d8791ae9 squash 2018-11-10 17:26:26 +01:00
f993b3dc60 [WIP] 2018-11-10 17:19:30 +01:00
8167148f00 mkdir pkg 2018-11-10 17:06:19 +01:00
fe1b40da97 Merge branch 'master' into alpine 2018-11-10 16:44:46 +01:00
3eaae31aae keep installation package 2018-11-10 16:44:37 +01:00
5e5ee7f181 adapt to alpine 2018-11-10 16:28:01 +01:00
f0a43458e3 another attempt at alpine 2018-11-10 15:49:13 +01:00
6fb12158b0 Merge branch 'master' into nginx-deb 2018-11-10 15:36:29 +01:00
69824d3497 Merge branch 'pull_prev' into nginx-deb 2018-11-10 15:33:39 +01:00
38da3057a3 more worker connections 2018-11-04 17:39:34 +01:00
8dc75bc553 improved commands 2018-11-03 21:11:55 +01:00
27ec24d567 Merged working scripts into master(alpine) 2018-09-09 22:51:47 +02:00
5 changed files with 53 additions and 13 deletions

View File

@ -7,10 +7,13 @@ pipeline:
docker:
image: plugins/docker
repo: repo.shimun.net/shimun/seafile
tag: alpine-sq
registry: repo.shimun.net
storage_path: /drone/.docker
secrets: ["docker_username", "docker_password"]
storage_path: /drone/.docker
cache_from: ["repo.shimun.net/shimun/seafile", "repo.shimun.net/shimun/seafile:nginx-deb", "repo.shimun.net/shimun/seafile:alpine"]
use_cache: true
experimental: true
squash: true
pull_image: false

View File

@ -1,4 +1,4 @@
FROM nginx:mainline
FROM frolvlad/alpine-glibc
VOLUME /opt/seafile
@ -6,11 +6,23 @@ EXPOSE 80 10001 12001 8000 8080 8082
ENV SEAF=/opt/seafile
ENV INSTALLPATH=$SEAF/seafile-server-latest
ENV CCNET_CONF_DIR=$SEAF/ccnet
ENV SEAFILE_CONF_DIR=$SEAF/seafile-data
ENV SEAFILE_CENTRAL_CONF_DIR=$SEAF/conf
ENV PYTHONPATH=/usr/lib/python2.7/site-packages
COPY requirements.txt /tmp/requirements.txt
RUN apt update && apt install locales -y && apt install -y --no-install-recommends procps openssl python2.7 sqlite3 python-mysqldb python-pil curl libjansson4 libfuse2 python-pip python-pip-whl python-setuptools \
&& pip install -r /tmp/requirements.txt && apt remove -y python-pip \
&& rm -rf /var/lib/apt/lists/* /tmp/requirements.txt
RUN echo http://dl-cdn.alpinelinux.org/alpine/edge/testing >> /etc/apk/repositories \
&& apk --no-cache add py-pip sqlite-dev py-mysqldb py-imaging py-pillow py-setuptools sqlite zlib curl bash openssl-dev libevent libselinux nginx \
&& pip install -r /tmp/requirements.txt && apk --no-cache del py-pip \
&& rm -f /tmp/requirements.txt \
&& mkdir -p /run/nginx
COPY conf /opt/seafile/conf
COPY conf /etc/seafile
@ -23,6 +35,8 @@ RUN ulimit -n 30000 && mkdir -p $SEAF/pids && \
ENV SEAF_UPGRADE_INTERVAL=3
WORKDIR $SEAF
ENTRYPOINT ["/sbin/seafile-server"]
#Defaults to run-upgrade options include: run, run-upgrade, upgrade, stop, stop-upgrade
CMD ["run-upgrade"]

View File

@ -1,5 +1,5 @@
events {
worker_connections 12;
worker_connections 64;
}
http{
@ -24,7 +24,7 @@ http{
server {
listen 80;
error_log syslog:server=unix:/dev/log;
error_log /dev/stderr;
access_log syslog:server=unix:/dev/log;
@ -76,7 +76,7 @@ http{
}
location /media {
try_files /var/www /opt/seafile/seafile-server-latest/seahub;
root /opt/seafile/seafile-server-latest/seahub;
}
}

View File

@ -115,6 +115,12 @@ case "$1" in
;;
maintanance)
$0 stop
if [ "$2" = "--fsck" ]; then
$LATEST/seaf-fsck.sh
fi
if [ "$2" = "--fsck-repair" ]; then
$LATEST/seaf-fsck.sh --repair
fi
$LATEST/seaf-gc.sh
$0 start
;;

View File

@ -58,8 +58,7 @@ def perform_upgrade_command(version,mysql=False,yes=True):
print len(current) == 1 and current[0] == 0
if len(current) == 1 and current[0] == 0: #Not installed
print("Running installer.")
installer = os.path.join(seaf_home,"seafile-server-%s" % version,"setup-seafile%s.sh" % ("-mysql" if mysql else ""))
if not call(["seafile-server","setup"],stdout=sys.stdout, stdin=sys.stdin):
if not call(["seafile-server","setup", os.path.join(seaf_home,"seafile-server-%s" % version) ],stdout=sys.stdout, stdin=sys.stdin):
sys.exit(1)
sys.exit(126)
script_re = "^upgrade_(\d+).(\d+)_(\d+).(\d+)\.sh$"
@ -79,9 +78,27 @@ def perform_upgrade_command(version,mysql=False,yes=True):
cmd.append(script)
call(["/bin/sh", "-c", ''.join(cmd)], stdout=sys.stdout, stdin=(None if yes else sys.stdin))
def install_command(url):
def download(url, version):
tmp = tempfile.mkdtemp()
if call(["/bin/sh", "-c", 'cd %s; curl %s | tar xzv' % (tmp, url)]) == 0:
filename = "server_%s.tar.gz" % version
pks = os.path.join(seaf_home, "pkg")
if not os.path.exists(pks):
os.mkdir(pks)
dest = os.path.join(pks, filename)
if os.path.exists(dest):
return dest
if call(["/bin/sh", "-c", 'curl %s --output %s/%s' % (url, tmp, filename)]) == 0:
shutil.move(os.path.join(tmp,filename), dest)
call(["/bin/chmod", "-w", dest])
return dest
else:
print("Download failed")
return 0
def install_command(url, version):
pkg = download(url, version)
tmp = tempfile.mkdtemp()
if pkg and call(["/bin/sh", "-c", 'cd %s; tar xzvf %s' % (tmp, pkg)]) == 0:
for f in os.listdir(tmp):
dest = os.path.join(seaf_home, os.path.basename(f))
if len(re.findall(version_re, f)) > 0:
@ -96,7 +113,7 @@ def install_command(url):
else: current = "0.0.0"
print("Upgrading from: %s -> %s" % (current, target_version))
perform_upgrade_command(target_version,mysql=("SEAF_MYSQL" in os.environ and os.environ["SEAF_MYSQL"]))
if os.exists(tmp) and len(os.listdir(tmp)) != 0:
if os.path.exists(tmp) and len(os.listdir(tmp)) != 0:
print("Failed to unpack update")
os.rmdir(tmp)
return 1
@ -119,7 +136,7 @@ def main_command(version="latest",page="https://www.seafile.com/en/download/"):
return perform_upgrade_command(version)
if install:
print("Installing: %s" % version)
sys.exit(install_command(install))
sys.exit(install_command(install, version))
else:
print("Couldn't determine download for %s" % version)
sys.exit(1)