️ 注意:本教程只适用于 macOS / Linux 操作系统。如果需要在 Windows 上部署 Overleaf,请先安装 WSL,之后在 WSL 中部署 Overleaf 。

本地部署 Overleaf

启动

克隆 Overleaf 仓库:

git clone https://github.com/overleaf/toolkit.git

进入 toolkit 目录并生成配置文件:

bin/init

下载镜像并启动 Overleaf 容器:

bin/up

注意,Overleaf 脚本中使用的命令行工具均为 GNU 工具,如果你在 macOS 上启动 Overleaf 时遇到工具报错,有可能是你使用了 BSD 工具的原因。请使用 brew 安装相应工具的 GNU 版本,如 coreutils

Overleaf 镜像下载完成并启动之后我们可以按下 Ctrl + C 停止容器。

之后启动 Overleaf 的时候,可以使用下面的命令让 Overleaf 在后台运行:

bin/start

参考:Quick-Start Guide

注册管理员帐户

Overleaf 容器启动之后,我们可以打开 http://localhost/launchpad 注册管理员帐户。之后我们可以用这个帐户登录 Overleaf 服务。

安装宏包

Overleaf 镜像自带的宏包很少,为了编译我们的 LaTeX 文档,往往需要安装其他宏包。

容器运行的状态下进入容器 Shell:

bin/shell

更新并安装全部宏包:

# 使用中科大镜像源
tlmgr repository set https://mirrors.ustc.edu.cn/CTAN/systems/texlive/tlnet
# 更新已安装的全部宏包,包括 tlmgr 自身
tlmgr update --self --all
# 安装 scheme-full 套件(CTAN 上的全部宏包)
tlmgr install scheme-full

️: 安装全部宏包的时间大约要 40 分钟左右

安装依赖包:

apt install ttf-mscorefonts-installer  # 安装 Windows 字体
apt install inkscape python3-pygments # 安装 TikZ & Syntax highlighter 依赖 # 导入 TeX Live 字体
ln -s /usr/local/texlive/2024/texmf-var/fonts/conf/texlive-fontconfig.conf /etc/fonts/conf.d/09-texlive.conf
fc-cache -fsv # 刷新字体缓存

你可能还要安装一些中文字体,将这些字体拷贝到 fonts 文件夹,然后运行下面的命令:

docker cp fonts sharelatex:/usr/local/share/fonts

参考:搭建本地版 Latex 编辑器,为你的毕业论文排版「减减负」| 少数派

VS Code 有一个叫 Overleaf 的插件,可以让 VS Code 连接到你搭建的 Overleaf 服务。

Troubleshooting

无法安装宏包

在安装宏包时你可能遇到如下错误:

tlmgr: Local TeX Live (2023) is older than remote repository (2024).
Cross release updates are only supported with
update-tlmgr-latest(.sh/.exe) --update
See https://tug.org/texlive/upgrade.html for details.

这是镜像使用的 TeX Live 版本过低导致的。如果你当前使用的不是最新的 ShareLaTeX 镜像,可以使用下面的命令更新镜像:

bin/upgrade

如果你已经在使用最新的 ShareLaTeX 镜像,那说明官方还没有给最新的 TeX Live 打镜像。你可以设置 TeX Live 使用旧版镜像源,或者更新当前容器中的 TeX Live 版本,也可以自己打一个包含新版 TeX Live 的镜像。

  • 设置旧版镜像源:

    tlmgr option repository https://mirrors.tuna.tsinghua.edu.cn/tex-historic-archive/systems/texlive/2021/tlnet-final/
  • 如果你要更新当前容器中的 TeX Live 版本,参见:Linux 更新 TeX Live

  • 如果你要自己打镜像,参见:自制 ShareLaTeX 镜像

打开 Web 界面时遇到 502 错误

如果遇到 502 错误,可能是端口冲突导致的。进入 config/overleaf.rc 修改一下端口号:

OVERLEAF_PORT=8080

部署到服务器上之后无法访问

Overleaf 的默认监听端口是 127.0.0.1:80,也就是只监听来自本地的 HTTP 访问请求。如果要开放所有 IP 的访问请求,需要修改 config/overleaf.rc 设置:

OVERLEAF_LISTEN_IP=0.0.0.0
OVERLEAF_PORT=80

这样所有地址都可以访问服务器的 80 端口来获取 Overleaf 服务。

无法启动 ShareLaTeX 容器

如果你在运行 bin/up 的过程中遇到这样的错误提示:

Initiating Mongo replica set...
Rebranding from ShareLaTeX to Overleaf
Starting with Overleaf CE and Server Pro version 5.0.0 the environment variables will use the Overleaf brand.
Previous versions used the ShareLaTeX brand for environment variables.
Your config/variables.env has 60 entries matching 'OVERLEAF_', expected prefix 'SHARELATEX_'.
Please align your config/version with the naming scheme of variables in config/variables.env.

说明当前配置设置的 Overleaf 版本过低。我们需要使用大版本号为 5 以上的版本。

编辑 config/version,使用新的版本号替代旧的版本号。你可以在 Docker Hub 上查看最新的版本号:sharelatex | DockerHub

撰写本文时,最新的版本号为:

5.0.3

无法启动 Mongo 容器

如果你在 WSL / macOS 上运行 bin/up 命令时遇到如下错误:

MongoNetworkError: connect ECONNREFUSED 127.0.0.1:27017
Waiting for Mongo... Please configure ALL_TEX_LIVE_DOCKER_IMAGES in /home/xiao/toolkit/config/variables.env You can read more about configuring Sandboxed Compiles in our documentation:
https://github.com/overleaf/overleaf/wiki/Server-Pro:-sandboxed-compiles#changing-the-texlive-image

这可能是由于 Mongo 访问绑定挂载目录的 bug 导致的。要解决这个问题,我们需要将 Mongo 和 Redis 的数据存储位置由绑定挂载目录改为命名卷。方法为:创建 config/docker-compose.override.yml 文件,填入以下内容:

# 创建卷
volumes:
mongo-data:
redis-data: # 挂载卷
services:
mongo:
volumes:
- mongo-data:/data/db redis:
volumes:
- redis-data:/data

然后重新运行 bin/up

参考:Persistent Data | Overleaf Docs

本地部署 Overleaf 服务的更多相关文章

  1. windows下百度离线人脸识别本地部署与使用(nodejs做客户端,c++做服务端,socket做通信)

    1.离线人脸识别本地部署 详情请阅读百度人脸识别官网 2.nodejs做socket通信的客户端 为什么不直接通过调用c++编译的exe获得人脸识别结果? 原因:exe运行时会加载很多模型而消耗很多时 ...

  2. 在 CentOS7 上部署 zookeeper 服务

    在 CentOS7 上部署 zookeeper 服务 1 用 SecureCRT 或 XShell 等 Linux 客户端工具连接至 CentOS7 服务器: 2 进入到 /usr/local/too ...

  3. Exceptionless 本地部署

    免费开源分布式系统日志收集框架 Exceptionless 前两天看到了这篇文章,亲身体会了下,确实不错,按照官方的文档试了试本地部署,折腾一番后终于成功,记下心得在此,不敢独享. 本地部署官方wik ...

  4. ArcGIS JavaScript API本地部署离线开发环境[转]

    原文地址:http://www.cnblogs.com/brawei/archive/2012/12/28/2837660.html 1 获取ArcGIS JavaScript API API的下载地 ...

  5. jsbin本地部署

    jsbin 本地运行 1.首先安装node.js,下载地址http://nodejs.org/ 安装完成后,使用node.js安装jsbin,如下:进入node环境,执行下面语句: $ npm ins ...

  6. ArcGIS API for JavaScript 4.x 本地部署之Apache(含Apache官方下载方法)

    IIS.Nginx都说了,老牌的Apache和Tomcat也得说一说(如果喜欢用XAMPP另算) 本篇先说Apache. 安装Apache 这个...说实话,比Nginx难找,Apache最近的版本都 ...

  7. 升级本地部署的CRM到Dynamics 365及部分新特性介绍。

    关注本人微信和易信公众号: 微软动态CRM专家罗勇 ,回复241或者20161226可方便获取本文,同时可以在第一间得到我发布的最新的博文信息,follow me!我的网站是 www.luoyong. ...

  8. Linux 自动化部署Rsyslog服务

    Linux 自动化部署Rsyslog服务 源码如下: #/bin/bash #该脚本用于自动化部署Ryslog服务配置 #作者:雨中落叶 #博客:https://www.cnblogs.com/yuz ...

  9. Linux下部署Samba服务环境的操作记录

    关于Linux和Windows系统之间的文件传输,很多人选择使用FTP,相对较安全,但是有时还是会出现一些问题,比如上传文件时,文件名莫名出现乱码,文件大小改变等问题.相比较来说,使用Samba作为文 ...

  10. CDH 5.16.1 离线部署 & 通过 CDH 部署 Hadoop 服务

    参考 Cloudera Enterprise 5.16.x Installing Cloudera Manager, CDH, and Managed Services Installation Pa ...

随机推荐

  1. sqlCel查询一个表中部分字段的数据后插入到另一个表中

    问题: 部门每天需要从后台系统将物流总表数据导出,Excel中整理出订单的物流发货渠道和发货时间,再手动导入到数据库中,整个过程不麻烦,但在Excel中比较繁琐. 需求: 将这个繁琐的过程变得更简单, ...

  2. vulnhub - Geisha

    vulnhub - Geisha 描述 Machine Name: Geisha Author : SunCSR Goal: Get the root flag of the target. Diff ...

  3. Spring PropertySource,获取指定application.properties文件

    @PropertySource注解的使用 @PropeertySource,指定加载配置文件 配置文件映射到实体类 使用@Value映射到具体的java属性 CustomConfig.java pac ...

  4. SpringBoot2.X新版本配置拦截器在项目中的使用

    拦截器:和过滤器用途基本类似 SpringBoot2.X新版本配置拦截器 implements WebMvcConfigure 自定义拦截器 HandlerInterceptor preHandle: ...

  5. PHP 使用非对称加密算法

    加密的类型: 在日常设计及开发中,为确保数据传输和数据存储的安全,可通过特定的算法,将数据明文加密成复杂的密文.目前主流加密手段大致可分为单向加密和双向加密. 单向加密:通过对数据进行摘要计算生成密文 ...

  6. [oeasy]python0081_[趣味拓展]ESC键进化历史_键盘演化过程_ANSI_控制序列_转义序列_CSI

    光标位置 回忆上次内容 上次了解了 新的转义模式 \033 逃逸控制字符 escape 这个字符 让字符串 退出标准输出流 进行控制信息的设置 可以设置 光标输出的位置       ​   添加图片注 ...

  7. [oeasy]python0095_乔布斯求职_雅达利_atari_breakout_打砖块_布什内尔_游戏机_Jobs

    编码进化 回忆上次内容 上次 我们回顾了 电子游戏的历史 从 电子游戏鼻祖 双人网球 到 视频游戏 PingPong 再到 街机游戏 Pong 雅达利 公司 来了 嬉皮士 捣乱? 布什内尔 会如何 应 ...

  8. oeasy教您玩转vim - 15 - # 行内查找

    行头行尾 回忆上节课内容 上次学了直接跳到开头和结尾 最重要的就是 ^.$ ^ 到开头 $ 到结尾 I 相当于^i A 相当于$a 查找帮助 还有什么呢? 还是继续在 motion 里面 ^ .$ 之 ...

  9. [oeasy]python0011_ 字符序号_ordinal_ord

    ​ 序号(ordinal) 回忆上次内容 ​hello world​​ 不是从来就有的 来自于​​unix​​和​​c​​ 虽然我们今天有各种先进的学习手段 最早的高级语言学习是从最早的那张打字机用纸 ...

  10. 适用于 .NET 的现代化、流畅、可测试的HTTP客户端库

    前言 今天大姚给大家分享一个.NET开源(MIT License).免费.现代化.流畅.可测试.可移植的URL构建器和HTTP客户端库:Flurl. 项目介绍 Flurl是一个集现代性.流畅性.异步性 ...