本文最后更新于 2024-07-12,

若内容或图片失效,请留言反馈。部分素材来自网络,若不小心影响到您的利益, 请联系我 删除。

本站只有Telegram群组为唯一交流群组, 点击加入

文章内容有误?申请成为本站文章修订者或作者? 向站长提出申请

1720725981803.webp

YOURLS是基于PHP的,一个可以让你在自己的服务器上运行的URL缩短服务。(已经有近10年的历史了!)

利用它,我们可以完全控制自己的数据,其中包括详细的统计、分析、还可以安装一些插件。

安装Docker🐳

利用Docker-compose搭建,易于更新

先建立一个文件夹

mkdir -p /root/data/docker_data/yourls

cd /root/data/docker_data/yourls

vim docker-compose.yml

docker-compose填入以下内容:

version: "3.5"
services:

  mysql:
    image: mysql:5.7.22              # 如果遇到不正确的数据库配置,或无法连接到数据库PDOException: SQLSTATE[HY000] [1045] 用户'yourls'@'yourls_service.yourls_default'的访问被拒绝(使用密码:是)   可以把5.7.22 改为 5.7
    environment:
      - MYSQL_ROOT_PASSWORD=my-secret-pw
      - MYSQL_DATABASE=yourls
      - MYSQL_USER=yourls
      - MYSQL_PASSWORD=yourls
    volumes:
      - ./mysql/db/:/var/lib/mysql
      - ./mysql/conf/:/etc/mysql/conf.d
    restart: always
    container_name: mysql

  yourls:
    image: yourls
    restart: always
    ports:
      - "8200:80"
    environment:
      YOURLS_DB_HOST: mysql
      YOURLS_DB_USER: yourls
      YOURLS_DB_PASS: yourls
      YOURLS_DB_NAME: yourls
      YOURLS_USER: admin      # 自己起一个名字
      YOURLS_PASS: admin      # 自己换一个登陆密码
      YOURLS_SITE: https://gao.ee  # 换成你自己的域名
      YOURLS_HOURS_OFFSET: 8
    volumes:
      - ./yourls_data/:/var/www/html   
    container_name: yourls_service
    links:
      - mysql:mysql

运行

docker-compose up -d

我们现在可以输入 http://ip:8200/访问了。

更新

cd /root/data/docker_data/yourls  # 进入docker-compose所在的文件夹
docker-compose pull    # 拉取最新的镜像
docker-compose up -d   # 重新更新当前镜像

卸载

cd /root/data/docker_data/yourls  # 进入docker-compose所在的文件夹
docker-compose down    # 停止容器,此时不会删除映射到本地的数据
cd ~
rm -rf /root/data/docker_data/yourls  # 完全删除映射到本地的数据

反向代理

参考教程:安装及使用

⚠️Nginx Proxy Manager(以下简称NPM)会用到80、443端口,所以本机不能占用(比如原来就有Nginx)

互联网使用请确保完成了域名解析

反向代理之后就可以用域名+/admin(即 https://你的域名/admin)来安装访问了。

1720726201257.webp
1720726207864.webp
1720726211597.webp

下载中文语言包

下载地址:https://github.com/ZvonimirSun/YOURLS-zh_CN/archive/refs/tags/v1.7.3.zip

wget https://github.com/ZvonimirSun/YOURLS-zh_CN/archive/refs/tags/v1.7.3.zip
apt install zip -y
unzip v1.7.3.zip

需要下载并解压到 /root/data/docker_data/yourls/yourls_data/user/languages目录,

1720726253503.webp

chown -R www-data:www-data zh_CN.mo  # 修改文件拥有者和组
chown -R www-data:www-data zh_CN.po  # 修改文件拥有者和组

然后修改 /root/data/docker_data/yourls/yourls_data/user/config.php

1720726298519.webp

如果你有宝塔,可以直接登陆宝塔:

1720726322430.webp

chown -R www-data:www-data zh_CN.mo
chown -R www-data:www-data zh_CN.po

1720726334127.webp

激活插件

1720726346450.webp

同一条链接对应多个短链接

同样是在刚刚修改语言的地方 /root/data/docker_data/yourls/yourls_data/user/config.php
下面一行,把这个改成 true就可以了

重启容器

cd /root/data/docker_data/yourls

docker-compose restart

主题

yourls虽然功能强大,但界面比较复古,好在可以更换主题,当然,你也可以自己开发。这里以 Sleeky主题 为例。

1720726395973.webp

Sleeky 主题包括前端和后台两个部分。下载解压 Sleeky 主题后可以看到两个文件夹 sleeky-frontendsleeky-backend ,前端只需要将 sleeky-frontend 中的文件复制到yourls网站根目录即可,后端则需要将 sleeky-backend 文件夹放到yourls目录下的 user/plugins 中,然后在后台管理(yourdomain.com/admin/plugins.php)中启动主题插件即可看到效果。

同时也要注意权限问题:

chown -R www-data:www-data sleeky-frontend

chown -R www-data:www-data sleeky-backend

你可以选择只安装前端或者只安装后端主题,如果你的前端主题没有 css 样式的话,可能是因为你的网站开启了 https,只需修改一下前面的 config.php 配置文件:

define( 'YOURLS_SITE', 'http://your-own-domain-here.com' );

将你的网站设置为 https://your-own-domain-here.com即可。

重启一下容器:

cd /root/data/docker_data/yourls

docker-compose restart