R2S+ZeroTier+Trilium

软路由使用ZeroTier搭建远程笔记

环境

  • 软路由硬件:友善 Nanopo R2S
  • 软路由系统:OpenWrt,使用第三方固件nanopi-openwrt
  • 内网穿透:ZeroTier
  • 远程笔记:Trilium

部署

安装ZeroTier

  • ZeroTier的作用是实现内网穿透,使得远程设备可以访问内网中的服务。安装ZeroTier的步骤请参考官方文档,软路由安装的系统为OpenWrt,因此使用OpenWrt ZeroTier插件进行安装。本文安装系统中已经自带ZeroTier插件,因此无需再次安装。

  • 安装完成后,在浏览器中输入http://192.168.2.1,进入ZeroTier的管理页面,添加网络ID,启动ZeroTier。网络ID需要在ZeroTier官网注册获取。在这里插入图片描述

  • 在管理页面中,点击网络——>接口,新建网络接口ZEROTIER。在这里插入图片描述基本设置在这里插入图片描述

物理设置(z字母开头的以太网适配器)在这里插入图片描述
防火墙设置 在这里插入图片描述

  • 网络——>防火墙设置,使得ZeroTier接口的数据和WAN接口的数据可以互通。在这里插入图片描述

  • 在ZeroTier网站查看是否有新节点接入,如果有的话,点击Join Network按钮,将新节点加入网络。

  • 如果ZeroTier网站没有新节点接入,则需要检查软路由的防火墙设置,确保ZeroTier接口的数据和WAN接口的数据可以互通。

安装trilium

  • trilium是一个开源的笔记软件,支持Markdown语法,支持多平台同步,支持插件扩展。可以运行在服务器端,也可以运行在客户端。本文使用服务器端部署,因此需要安装trilium。

  • 安装trilium的步骤请参考官方文档,软路由为Nanopi R2S,为ARM架构,因此需要使用trilium的docker安装方式。

  • 由于本系统也预装了docker,因此无需再次安装docker。但是由于根目录空间不足,因此需要切换docker的数据存储目录。一下是切换docker数据存储目录的步骤,有文心一眼生成,亲测有效,可根据实际情况修改:
    在OpenWrt系统中更改Docker的存储路径,可以按照以下步骤进行:

    1. 安装Docker(如果尚未安装):
      使用以下命令更新软件包列表并安装Docker:

      opkg update
      opkg install docker
      
    2. 停止Docker服务
      在修改Docker配置文件之前,需要停止Docker服务。使用以下命令:

      /etc/init.d/docker stop
      

      或者在某些OpenWrt版本中,可以使用:

      systemctl stop docker
      
    3. 创建新的存储目录
      选择一个磁盘空间更大的位置来作为新的Docker存储目录,例如/mnt/docker。然后创建该目录:

      mkdir -p /mnt/docker
      
    4. 修改Docker配置文件
      使用文本编辑器(如vinano)打开Docker的配置文件/etc/config/docker

      vi /etc/config/docker
      

      在配置文件中,找到并修改option data_root的值为新创建的存储目录的路径,例如:

      config docker 'docker'
          option data_root '/mnt/docker'
          # 其他配置项...
      

      保存并退出编辑器。

    5. (可选)安装适当的存储驱动
      如果需要更改Docker的存储驱动(如使用overlay2),则需要先安装相应的驱动。例如,安装overlay2驱动:

      opkg update
      opkg install kmod-fs-overlay2
      

      然后,在Docker配置文件中指定新的存储驱动(但通常这一步不是必需的,除非有特殊需求)。

    6. 重启Docker服务
      重新启动Docker服务以使更改生效:

      /etc/init.d/docker start
      

      或者在某些OpenWrt版本中,可以使用:

      systemctl start docker
      
    7. 验证更改
      确认Docker服务正在运行,并且Docker的存储路径已更改为新的目录。你可以通过查看Docker的日志或使用Docker命令来验证。

  • 16
    点赞
  • 20
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
使用r2dbc+mysql+springboot创建表需要以下步骤: 1. 配置MySQL连接信息,包括数据库名称、用户名、密码和MySQL的URL等。 2. 创建一个Java Bean,用于表示表中的字段和数据类型。例如,如果要创建一个名为person的表,可以在Java中创建一个名为Person的类,该类包含与表中字段对应的属性。 3. 创建一个Repository接口,用于定义插入、查询、更新和删除数据等操作。在接口中通过SQL语句进行定义,例如使用@Query注解定义插入数据的SQL语句。 4. 在Spring Boot应用程序启动时,使用Spring的自动化配置功能自动创建表。可以通过在应用程序的配置文件中添加spring.jpa.hibernate.ddl-auto属性来控制表的创建方式,例如可以将该属性设置为create或update等选项。 下面是一个简单的示例代码,用于创建一个名为person的表: 1. 在application.properties中添加MySQL数据库连接配置信息: ``` spring.r2dbc.url=r2dbc:mysql://localhost:3306/testdb spring.r2dbc.username=testuser spring.r2dbc.password=testpass ``` 2. 创建一个Person类,在其中定义表中的字段和数据类型: ```java @Data public class Person { private Long id; private String firstName; private String lastName; } ``` 3. 创建一个PersonRepository接口,在其中定义对person表的操作: ```java public interface PersonRepository extends ReactiveCrudRepository<Person, Long> { @Query("INSERT INTO person (first_name, last_name) VALUES (:firstName, :lastName)") Mono<Void> insert(@Param("firstName") String firstName, @Param("lastName") String lastName); @Query("SELECT * FROM person WHERE id = :id") Mono<Person> findById(@Param("id") Long id); } ``` 4. 在启动类中添加@EnableR2dbcRepositories注解,开启R2DBC仓库的自动化配置: ```java @SpringBootApplication @EnableR2dbcRepositories public class Application { public static void main(String[] args) { SpringApplication.run(Application.class, args); } } ``` 5. 启动应用程序,Spring Boot将自动创建名为person的表。如果表已经存在,则不会进行任何操作。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值