使用docker搭建overleaf环境

使用docker搭建overleaf环境

安装docker

可参考笔记: ubuntu docker gpu环境安装

如果不需要安装gpu版本的docker,可使用下列命令

shell 复制代码
curl -fsSL https://mirrors.ustc.edu.cn/docker-ce/linux/ubuntu/gpg | sudo apt-key add -
sudo apt-get update
sudo apt install docker-ce docker-ce-cli containerd.io docker-compose

安装Overleaf

将overleaf代码clone到本地

shell 复制代码
git clone https://github.com/overleaf/toolkit.git ./overleaf

如果github仓库下载不了,则可以使用https://gitee.com/xiaoxia722/overleaf_toolkit.git

进入代码目录进行初始化

shell 复制代码
cd ./overleaf
bin/init

此时将生成三个配置文件

shell 复制代码
ls config/
overleaf.rc variables.env version

更改overleaf.rc配置文件

shell 复制代码
SHARELATEX_LISTEN_IP=0.0.0.0(接收外网请求)
SHARELATEX_PORT=12150(overleaf的端口,可以不改)

启动服务

shell 复制代码
sudo bin/up

刚开始会拉取大量的log,然后使用ctrl+c退出

重新启动

shell 复制代码
sudo bin/start

安装完整texlive包

以上安装的overleaf配套的LaTeX不是完整版,所以需要继续下载。首先进入容器的bash:

shell 复制代码
sudo docker exec -it sharelatex /bin/bash
cd /usr/local/texlive

然后执行以下命令:1

shell 复制代码
# 下载并运行升级脚本
wget http://mirror.ctan.org/systems/texlive/tlnet/update-tlmgr-latest.sh
sh update-tlmgr-latest.sh -- --upgrade

# 更换texlive的下载源
tlmgr option repository https://mirrors.sustech.edu.cn/CTAN/systems/texlive/tlnet/

# 升级tlmgr
tlmgr update --self --all

# 安装完整版texlive(时间比较长,不要让shell断开)
tlmgr install scheme-full
# 退出sharelatex的命令行界面,并重启sharelatex容器
exit
docker restart sharelatex

至此,overleaf的安装完成配置Nginx

可以通过访问http://公网IP:映射的端口/launchpad,默认端口下可以访问本地接口http://127.0.0.1:80/launchpad注册管理员账号

其他情况下可以访问http://公网IP:映射的端口进行使用

反向代理

在Nginx配置文件中加入该配置,其中反向代理端口要与之前配置的相同。

sehll 复制代码
server {
    listen 80;
    listen [::]:80;
    
    # 外网访问域名
    server_name domain;
    return 302 https://$server_name$request_uri;
}

server {
    
    listen 443 ssl http2;
    listen [::]:443 ssl http2;

    # 外网访问域名
    server_name domain;

    index index.html;

    # 以下两行配置SSL证书
    ssl_certificate         /path/domain.cer;
    ssl_certificate_key     /path/.acme.sh/xlz.pub/domain.key;

    ssl_session_timeout 5m;
    ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:ECDHE:ECDH:AES:HIGH:!NULL:!aNULL:!MD5:!ADH:!RC4;
    ssl_protocols TLSv1 TLSv1.1 TLSv1.2;

    add_header Strict-Transport-Security "max-age=31536000; includeSubdomains;";

    server_tokens off;

    add_header X-Frame-Options SAMEORIGIN;

    add_header X-Content-Type-Options nosniff;

    client_max_body_size 50M;
 
    location / {
        proxy_set_header X-Forwarded-Proto $scheme;
        proxy_http_version 1.1;
        proxy_set_header Upgrade $http_upgrade;
        proxy_set_header Connection "upgrade";
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_read_timeout 3m;
        proxy_send_timeout 3m;
 
        proxy_pass http://overleaf所在IP地址:overleaf监听端口;
    }
}
相关推荐
O&REO2 小时前
单机部署kubernetes环境下Overleaf-基于MicroK8s的Overleaf应用部署指南
云原生·容器·kubernetes
运维小文3 小时前
K8S资源限制之LimitRange
云原生·容器·kubernetes·k8s资源限制
登云时刻3 小时前
Kubernetes集群外连接redis集群和使用redis-shake工具迁移数据(二)
redis·容器·kubernetes
wuxingge11 小时前
k8s1.30.0高可用集群部署
云原生·容器·kubernetes
志凌海纳SmartX12 小时前
趋势洞察|AI 能否带动裸金属 K8s 强势崛起?
云原生·容器·kubernetes
锅总12 小时前
nacos与k8s service健康检查详解
云原生·容器·kubernetes
BUG弄潮儿13 小时前
k8s 集群安装
云原生·容器·kubernetes
意疏13 小时前
【Linux 篇】Docker 的容器之海与镜像之岛:于 Linux 系统内探索容器化的奇妙航行
linux·docker
墨鸦_Cormorant13 小时前
使用docker快速部署Nginx、Redis、MySQL、Tomcat以及制作镜像
redis·nginx·docker
Code_Artist13 小时前
Docker镜像加速解决方案:配置HTTP代理,让Docker学会科学上网!
docker·云原生·容器