linuxserver/clarkson此镜像已弃用。我们将不再为此镜像提供支持,也不会对其进行更新。建议使用Hammond作为替代:[***]
Clarkson是一个基于Web的仪表板应用,为您提供简洁清晰的界面,用于记录所有车辆的加油数据。该应用支持完整的多用户功能,以及每个用户多辆车的管理。每当您给汽车或摩托车加油时,保留收据并在Clarkson中记录数据。
!clarkson
我们的镜像支持多种架构,如x86-64、arm64和armhf。我们利用docker manifest实现多平台识别。只需拉取lscr.io/linuxserver/clarkson即可获取适合您架构的正确镜像,您也可以通过标签拉取特定架构的镜像。
此镜像支持的架构如下:
| 架构 | 标签 |
|---|---|
| x86-64 | amd64-latest |
| arm64 | arm64v8-latest |
| armhf | arm32v7-latest |
*Clarkson需要MySQL 5.7.版本,请确保MySQL在启动此容器之前已运行。
建议您在首次运行容器之前创建clarkson数据库,然后创建一个对该数据库具有权限的用户。在运行应用之前创建数据库非常重要,因为"clarkson"用户无权代表您创建数据库。当然,您可以使用"root"用户(它具有自动创建数据库的能力),但不推荐这样做。
sqlCREATE SCHEMA `clarkson`; CREATE USER 'clarkson_user' IDENTIFIED BY 'supersecretpassword'; GRANT ALL ON `clarkson`.* TO 'clarkson_user';
容器运行后,将执行初始MySQL迁移,自动在数据库中创建所有表和存储过程。之后应用将立即启动。您需要注册一个初始用户,该用户将成为应用的管理员。所有后续用户将是标准用户。您可以通过将容器的ENABLE_REGISTRATIONS标志设置为false来禁用注册功能。这不会隐藏"注册"链接,但会禁用注册功能。
以下是一些示例代码片段,帮助您开始创建容器。
yaml--- version: "2.1" services: clarkson: image: lscr.io/linuxserver/clarkson container_name: clarkson environment: - PUID=1000 - PGID=1000 - MYSQL_HOST=<mysql_host> - MYSQL_USERNAME=<mysql_username> - MYSQL_PASSWORD=<mysql_password> - ENABLE_REGISTRATIONS=<true/false> - TZ=Europe/London ports: - 3000:3000 restart: unless-stopped
bashdocker run -d \ --name=clarkson \ -e PUID=1000 \ -e PGID=1000 \ -e MYSQL_HOST=<mysql_host> \ -e MYSQL_USERNAME=<mysql_username> \ -e MYSQL_PASSWORD=<mysql_password> \ -e ENABLE_REGISTRATIONS=<true/false> \ -e TZ=Europe/London \ -p 3000:3000 \ --restart unless-stopped \ lscr.io/linuxserver/clarkson
容器镜像通过运行时传递的参数进行配置(如上所示)。这些参数用冒号分隔,表示<外部>:<内部>。例如,-p 8080:80会将容器内的80端口暴露出来,可通过主机IP的8080端口访问。
| 参数 | 功能 |
|---|---|
-p 3000 | Web界面端口 |
-e PUID=1000 | 用户ID - 详见下文说明 |
-e PGID=1000 | 组ID - 详见下文说明 |
-e MYSQL_HOST=<mysql_host> | 指向MySQL数据库的地址,可以是Docker主机名或IP |
-e MYSQL_USERNAME=<mysql_username> | 有权访问clarkson数据库的用户 |
-e MYSQL_PASSWORD=<mysql_password> | 该用户的密码 |
-e ENABLE_REGISTRATIONS=<true/false> | 默认值为_false_。 设置为_true_时允许新用户注册 |
-e TZ=Europe/London | 指定时区,例如Europe/London |
您可以通过使用特殊的前缀FILE__从文件中设置任何环境变量。
例如:
bash-e FILE__PASSWORD=/run/secrets/mysecretpassword
这将根据/run/secrets/mysecretpassword文件的内容设置PASSWORD环境变量。
对于我们所有的镜像,您可以使用可选的-e UMASK=022设置来覆盖容器内服务的默认umask设置。请注意,umask不是chmod,它基于其值减去权限,而不是添加。请在寻求支持前阅读此处了解更多信息。
使用卷(-v标志)时,主机OS和容器之间可能会出现权限问题。我们通过允许您指定用户PUID和组PGID来避免此问题。
确保主机上的任何卷目录都由您指定的相同用户拥有,这样权限问题就会迎刃而解。
在本例中,PUID=1000和PGID=1000,您可以通过以下命令查找自己的PUID和PGID:
bash$ id username uid=1000(dockeruser) gid=1000(dockergroup) groups=1000(dockergroup)
我们发布了各种Docker Mods,以启用容器内的附加功能。可通过上方的动态徽章访问此镜像可用的Mods列表(如有)以及可应用于我们任何镜像的通用Mods。
docker exec -it clarkson /bin/bashdocker logs -f clarksondocker inspect -f '{{ index .Config.Labels "build_version" }}' clarksondocker inspect -f '{{ index .Config.Labels "build_version" }}' lscr.io/linuxserver/clarkson我们的大多数镜像是静态的、版本化的,需要更新镜像并重新创建容器才能更新内部的应用。除了一些例外(如nextcloud、plex),我们不建议或支持在容器内更新应用。请参考上面的应用设置部分,了解是否推荐对此镜像进行应用更新。
以下是更新容器的说明:
docker-compose pull
docker-compose pull clarksondocker-compose up -d
docker-compose up -d clarksondocker image prunedocker pull lscr.io/linuxserver/clarksondocker stop clarksondocker rm clarkson/config文件夹和设置将被保留)docker image prune拉取其标签的最新镜像,并在一次运行中使用相同的环境变量替换它:
bashdocker run --rm \ -v /var/run/docker.sock:/var/run/docker.sock \ containrrr/watchtower \ --run-once clarkson
您还可以删除旧的悬空镜像:docker image prune
注意: 我们不认可将Watchtower用作自动更新现有Docker容器的解决方案。事实上,我们通常不鼓励自动更新。但是,对于您忘记原始参数的容器,这是一个有用的一次性手动更新工具。从长远来看,我们强烈建议使用Docker Compose。
如果您想为开发目的对这些镜像进行本地修改,或只是为了自定义逻辑:
bashgit clone [***] cd docker-clarkson docker build \ --no-cache \ --pull \ -t lscr.io/linuxserver/clarkson:latest .
可以使用multiarch/qemu-user-static在x86_64硬件上构建ARM变体:
bashdocker run --rm --privileged multiarch/qemu-user-static:register --reset
注册后,您可以使用-f Dockerfile.aarch64指定要使用的dockerfile。
manifest unknown 错误
TLS 证书验证失败
DNS 解析超时
410 错误:版本过低
402 错误:流量耗尽
身份认证失败错误
429 限流错误
凭证保存错误
来自真实用户的反馈,见证轩辕镜像的优质服务