找回密码
 立即注册
首页 业界区 业界 本地部署overleaf服务帮助latex论文编写

本地部署overleaf服务帮助latex论文编写

求几少 3 天前
是的,overleaf是一个很好的服务,提供了立刻上手就可以编写的latex文章的服务.但是,overleaf会面对latex超时,所以需要付钱的情况,这常出现在编写期刊的论文的情况.
因为时效性,所以,过去的一些操作已经不适用于新版本的overleaf的本地化部署,该博客提供了最新的部署方式指导(以及一些常见问题修复)
部署overleaf服务

官方仓库docker compose yaml部署overleaf服务存在一定的问题,无法连接mongodb数据库
所以,使用官方提供的Overleaf Toolkit,该工具提供了构建好的一些可执行工具帮助部署和使用
requirements


  • git
  • docker
  • docker compose
不会高效地安装docker依赖?可以参考博客[tldr] debian系用户配置使用docker
clone repo
  1. git clone --depth=1 https://github.com/overleaf/toolkit.git ./overleaf-toolkit
复制代码
--depth=1的作用是只clone最新一次的内容,这个可以有效地减少需要下载的内容
出现了网络问题,无法下载,可以试一下github520cli开源项目,使用方式参考博客github520cli解决无法github访问问题
该仓库提供了overleaf需要的一系列工具,文档可以参考官方仓库的README
docker部署

需要三个docker image

  • redis
  • mongodb
  • sharelatex
如果网络问题可以考虑proxy或者国内镜像源,但是sharlatex不在国内的镜像源的白名单里面.
检查bin/文件夹中的内容,这里面包含了一些通过docker compose运行的可执行文件.
  1. backup-config*   doctor*      init*   rename-env-vars-5-0*  shell*  up*                       
  2. dev/             error-logs*  logs*   rename-rc-vars*       start*  upgrade*                  
  3. docker-compose*  images*      mongo*  run-script*           stop*   
复制代码
使用ls指令检查可执行文件
主要需要的文件有start,stop,shell
也可以通过docker compose指令直接启动服务
使用./bin/up启动服务
使用./bin/up -d让程序在后台运行
使用./bin/stop停止服务
使用./bin/start重新启动服务
使用./bin/shell连接进入容器内部
你可以通过docker-compose exec -it sharelatex bash取得类似的效果
启动三个服务,其中,sharelatex耗费最多的时间,每次启动都是需要花费时间的,并且,这个容器内部还包含了nginx服务
安装依赖(解决BUG)

在编写一些latex文档的时候,可能存在依赖缺失的问题,例如[Latex] CTEX解决File "xxx.sty" not found问题
通过检查github issue978得到问题的解决办法,主要是通过更新textlive的方式
该博客中提供了更新的方式
Upgrade from TeX Live 2024 to 2025官方提供了很好的升级textlive版本的方式,其中,推荐快速安装的方式
进入容器

一些的安装和更新操作需要在容器内部进行,所以,先使用./bin/shell进入容器内部shell
去到临时文件夹开始操作
  1. cd /tmp # working directory of your choice
复制代码
下载需要的文件
  1. wget https://mirror.ctan.org/systems/texlive/tlnet/install-tl-unx.tar.gz
复制代码
解压
  1. zcat < install-tl-unx.tar.gz | tar xf - # note final - on that command line
复制代码
前往解压出来的文件夹
  1. cd install-tl-*
复制代码
这个*需要换成对应的数字
(可选)更换textlive镜像源,参考知乎-更换textlive的镜像源
  1. tlmgr option repository https://mirrors.aliyun.com/CTAN/systems/texlive/tlnet
复制代码
这个是永久性换源
安装
  1. perl ./install-tl --no-interaction # as root or with writable destination
  2. # may take several hours to run
复制代码
这个安装过程很漫长,大概有4900个pkg需要安装,下载完成之后安装也需要一定的时间
添加环境变量
需要添加/usr/local/texlive/2025/bin/x86_64-linux/到环境变量中
这个变量名因为安装的不同也会不一样
因为overleaf启动的时候是通过/usr/bin/python3 -u /sbin/my_init指令进行的操作,所以,需要在python代码中添加环境变量的指令
使用vim /sbin/my_init指令修改启动方式
  1. # 设置环境变量
  2. os.environ['PATH'] = f"/usr/local/texlive/2025/bin/x86_64-linux/{os.pathsep}{os.environ.get('PATH', '')}"
复制代码
1.png

重启服务

安装全部的服务之后,然后,需要重启服务,使用docker restart sharlatex
只需./bin/stop然后./bin/start即可
使用服务

第一次登陆的时候会创建管理员用户,管理员用户再添加其他用户.
后续使用的时候登陆一般用户访问服务即可

来源:程序园用户自行投稿发布,如果侵权,请联系站长删除
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!
您需要登录后才可以回帖 登录 | 立即注册