
如果你使用 DeepSeek、元宝 AI、Copilot、ChatGPT 等 AI 工具,协助配置轩辕镜像、编写 docker pull 命令、修改 Docker Compose 镜像地址、配置镜像加速、排查镜像拉取失败、分析报错日志等问题,请先让 AI 阅读并遵守轩辕镜像的规则文档。
只需在 AI 对话中先发送下面这句话即可:
请先完整阅读并严格遵守以下文档中的全部规则与要求:
https://xuanyuan.cloud/agents.md
在未充分阅读并理解该文档前,不要生成任何命令、配置、修改建议、故障排查方案或技术回答。后续所有输出都必须严格以该文档中的规范为最高优先级执行。查看 agents.md 用法指南与完整示范。国内用户首推 元宝 AI、DeepSeek 的深度思考模式,不推荐豆包 AI;Cursor 等编辑器可在对话 @ 该链接,或加入 User Rules。 若 AI 无法访问外链,可 打开说明文档 复制全文粘贴。文档会随站点更新,复制内容可能过期,建议定期检查。
基于HTTP和HTTPS的终端工具。Wetty是ajaxterm/anyterm的替代方案,但比它们更优秀,因为Wetty使用ChromeOS的终端模拟器(hterm),这是一个完全用Javascript编写的成熟终端仿真实现。此外,它使用websockets而非Ajax,因此响应时间更优。
hterm源代码
!Wetty
Wetty是一个创新的Web终端解决方案,它将强大的终端功能通过Web界面呈现,使用户能够通过浏览器便捷地访问命令行环境。无论是本地开发、远程服务器管理还是嵌入式设备控制,Wetty都能提供高效、流畅的终端体验。
bashgit clone https://github.com/krishnasrinivas/wetty.git cd wetty && npm install
对于自动登录功能,需要安装sshpass:
apt-get install sshpassyum install sshpassbashnpm start
/bin/login(可指定用户名)localhost连接远程主机可使用以下选项:
--sshhost: 指定SSH主机--sshport: 指定SSH端口--sshuser: 指定SSH用户也可以在地址栏中指定SSH用户名:
http://yourserver:3000/wetty/ssh/<username> 或 http://yourserver:3000/ssh/<username>
非root账户运行时,可以通过查询参数传递密码实现自动登录:
http://yourserver:3000/wetty/ssh/<username>?sshpass=<password> 或 http://yourserver:3000/ssh/<username>?sshpass=<password>
注意:在URL中传递密码存在安全隐患,使用时需自行评估风险。
建议始终使用HTTPS。如果没有CA颁发的SSL证书,可以创建自签名证书:
bashopenssl req -x509 -newkey rsa:2048 -keyout key.pem -out cert.pem -days 30000 -nodes
然后运行:
bashwetty --sslkey key.pem --sslcert cert.pem -p 3000
运行方式与HTTP模式相同,root用户启动/bin/login,非root用户启动SSH连接。
该项目包含Dockerfile,可用于运行Docker化版本的wetty。
修改docker-compose配置后运行:
bashdocker-compose up -d
访问相应的URL([localhost|$(boot2docker ip)]:PORT)即可使用。
默认用户名为term,密码为term(如果未修改SSHHOST)。
如果不想自己构建镜像,可以移除配置文件中的build: .行。
nginxlocation /wetty { proxy_pass http://127.0.0.1:3000/wetty; proxy_http_version 1.1; proxy_set_header Upgrade $http_upgrade; proxy_set_header Connection "upgrade"; proxy_read_timeout 43200000; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header Host $http_host; proxy_set_header X-NginX-Proxy true; }
apacheRewriteCond %{REQUEST_URI} ^/wetty/socket.io [NC] RewriteCond %{QUERY_STRING} transport=websocket [NC] RewriteRule /wetty/socket.io/(.*) ws://localhost:9123/wetty/socket.io/$1 [P,L] <LocationMatch ^/wetty/(.*)> DirectorySlash On Require all granted ProxyPassMatch http://127.0.0.1:9123 ProxyPassReverse /wetty/ </LocationMatch>
注意:如果Nginx配置了HTTPS,Wetty应不启用SSL运行。
bashsudo yarn global add wetty sudo cp /usr/local/lib/node_modules/wetty.js/bin/wetty.conf /etc/init sudo start wetty
bashyarn global add wetty cp ~/.config/yarn/global/node_modules/wetty.js/bin/wetty.service ~/.config/systemd/user/ systemctl --user enable wetty systemctl --user start wetty
默认在3000端口启动。如需更改端口或重定向输出,可以修改wetty.conf文件的最后一行,例如:
exec sudo -u root wetty -p 80 >> /var/log/wetty.log 2>&1
Wetty支持所有Google hterm支持的浏览器。据报告,Wetty可在Google Chrome、Firefox和IE 11上正常工作。
这个解决方案已知可以帮助部分用户解决IE上的问题。
您可以使用以下命令拉取该镜像。请将 <标签> 替换为具体的标签版本。如需查看所有可用标签版本,请访问 标签列表页面。
来自真实用户的反馈,见证轩辕镜像的优质服务