本地部署开源网络书签与内容管理工具 Karakeep 并实现外部访问

Karakeep 是一款开源自托管的一站式网络书签与内容管理工具,能自动抓取并永久存档网页内容,支持全文搜索、AI 智能标签分类、笔记记录以及离线阅读,非常适合需要构建个人知识库或对隐私有较高要求的用户。本文将详细介绍如何利用 Docker 在局域网内部署 Karakeep 并结合路由侠实现外网访问局域网内部署的 Karakeep 。

第一步,本地部署安装 Karakeep

1,本教程操作环境为 Linux Ubuntu 系统,Karakeep 依赖 Docker 运行,我们需要先确保你的系统上已经安装了 Docker 。如果尚未安装,可以参考文档进行安装,点此查看

2,安装 Docker Compose 。

复制代码
sudo curl -L "https://github.com/docker/compose/releases/download/$(curl -s https://api.github.com/repos/docker/compose/releases/latest | grep -Po '"tag_name": "\K.*\d')" /usr/local/bin/docker-compose

3,创建并进入项目目录。

复制代码
mkdir -p /data/karakeep && cd /data/karakeep

4,创建 docker-compose.yml 文件。

复制代码
sudo vim docker-compose.yml

写入以下内容:

复制代码
services:
  web:
    image: ghcr.io/karakeep-app/karakeep:release
    restart: unless-stopped
    ports:
      - "3000:3000"
    volumes:
      - ./data:/data
    env_file:
      - .env
    environment:
      MEILI_ADDR: http://meilisearch:7700
      BROWSER_WEB_URL: http://chrome:9222
      DATA_DIR: /data
    depends_on:
      - meilisearch
      - chrome

  chrome:
    image: registry.cn-hangzhou.aliyuncs.com/jeson/alpine-chrome:124
    restart: unless-stopped
    command:
      - --no-sandbox
      - --disable-gpu
      - --disable-dev-shm-usage
      - --remote-debugging-address=0.0.0.0
      - --remote-debugging-port=9222
      - --hide-scrollbars

  meilisearch:
    image: getmeili/meilisearch:v1.13.3
    restart: unless-stopped
    env_file:
      - .env
    environment:
      MEILI_NO_ANALYTICS: "true"
    volumes:
      - ./meilisearch:/meili_data

volumes:
  meilisearch:
  data:

5,生成必要的密钥并创建 .env 文件。

复制代码
openssl rand -base64 36
复制代码
sudo vim .env

写入以下内容:

复制代码
KARAKEEP_VERSION=release
NEXTAUTH_SECRET=你的随机密钥
MEILI_MASTER_KEY=你的随机密钥
NEXTAUTH_URL=http://你的服务器 IP:3000

6,启动 Karakeep 服务。

复制代码
docker-compose up -d

7,打开浏览器访问地址 http://你的服务器 IP:3000 ,就能看到你部署的 Karakeep 登录界面了。

第二步,外网访问本地 Karakeep

安装路由侠内网穿透。

1,当前未提供网页管理,需要先在任意一台 Windows 机器安装路由侠 Windows 版本,用作跨机器管理。点此下载

2,在路由侠客户端主界面,进入" 设备管理 ",点击右下角的" 添加设备 ",此时可查看到对应的安装码,此安装码用于将设备添加到对应账号下,可选中后复制。

3,直接下载后导入:

复制代码
wget https://dl.luyouxia.com:8443/v2/lyx-docker-x86_64.tar
docker load -i lyx-docker-x86_64.tar

4,然后使用该镜像启动容器。

复制代码
docker run --name lyx -it --restart=always --net=host -e code=这里填写安装码 luyouxia/lyx

5,此时,需要等待下载和安装的过程,如果一切正常,最终可以看到一些输出,并且可以看到如下提示:

复制代码
[Device] Logged in. Token: ....

这就表示安装成功了。

当前 Linux 终端这边,如果是使用的上面的命令,Docker 是运行在前台,此时可以按住 Ctrl + C ,退出路由侠,容器也将退出。现在可以使用以下命令将其放入后台持续运行:

复制代码
docker start lyx

注意如果容器删除,重新 docker run ,将创建为新的设备。

需要注意的是,因为容器参数已经添加了 --restart=always ,这样开机就会自动启动,不需要再手动启动路由侠了。

6,现在回到 Windows 这边设备列表,点击右上角的 × 返回主界面,再次进入,就可以找到这个设备,可以修改名称。

7,回到主界面,点击【内网映射】。

8,注意右上角的设备名称下拉框,这里选中刚刚添加的设备名称,此时在这个界面上添加的映射,就属于刚刚这个设备。添加或修改一般需要等待 30 秒,容器中的路由侠进程就会更新并加载。切换好设备后,点击【添加映射】。

9,选择【原生端口】。

10,在内网地址填写你的服务器 IP 和 Karakeep 端口 3000 后点击【创建】按钮,如下图。

11,创建好后,就可以看到一条映射的公网地址,鼠标右键点击【复制地址】。

12,在外网电脑上,打开浏览器,在地址栏输入从路由侠生成的外网地址,就可以看到内网部署的 Karakeep 登录界面了。

相关推荐
m0_59136473几秒前
JavaScript中Object-hasOwn作为现代安全检测方案
jvm·数据库·python
m0_624578592 分钟前
html标签怎么避免标签嵌套错误_div不能放在p内原因【详解】
jvm·数据库·python
曦夜日长11 分钟前
Linux系统篇,权限(二):缺省权限、最终权限的计算、文件隔离的两种方式
linux·运维·服务器
霸道流氓气质18 分钟前
SpringAIAlibaba整合百炼平台实现多MCP Server调用示例及指定某MCP Server调用示例
数据库
2301_7693406725 分钟前
怎样导出用于负载测试的样本数据_LIMIT限制数据量提取
jvm·数据库·python
许彰午36 分钟前
政务远程帮办部署踩坑实录——从互联网到政务外网
开发语言·网络·政务
kebidaixu36 分钟前
OK3568开发板更新Ubuntu22.04方法总结
linux·运维·服务器
2401_850491651 小时前
c++如何通过文件映射mmap在多进程间实现高性能数据共享【进阶】
jvm·数据库·python
iuvtsrt1 小时前
PHP 中高效查找 CSV 行并获取前后指定偏移行的数据
jvm·数据库·python
m0_463672201 小时前
MySQL从库出现大量锁等待怎么办_分析从库执行计划与锁日志
jvm·数据库·python