Categories
java

spring activiti starter

<dependency>
    <groupId>org.activiti</groupId>
    <artifactId>activiti-spring-boot-starter</artifactId>
    <version>7.1.0.M6</version>
</dependency>

注入activiti 组件


初始化activiti 表

以下单元测试用例 用来初始化 activiti 表
@SpringBootTest
class ActivitiApplicationTests {

    @Test
    void contextLoads() {
        ProcessEngineConfiguration processEngineConfiguration = ProcessEngineConfiguration.createProcessEngineConfigurationFromResource("activiti.cfg.xml");
        processEngineConfiguration.buildProcessEngine();
    }

}

activiti.cfg.xml 是在类目录下的 一个spring beans 配置文件

<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xsi:schemaLocation="http://www.springframework.org/schema/beans   http://www.springframework.org/schema/beans/spring-beans.xsd">


    <bean id="dataSource" class="com.alibaba.druid.spring.boot.autoconfigure.DruidDataSourceWrapper" >
        <property name="driverClassName" value="com.mysql.cj.jdbc.Driver" />
        <property name="url" value="jdbc:mysql://mysql.robinluo.top/activiti?characterEncoding=UTF-8&amp;nullCatalogMeansCurrent=true&amp;serverTimezone=GMT&amp;useSSL=false" />
        <property name="username" value="admin" />
        <property name="password" value="RobinLuo@2021" />
    </bean>


    <bean id="processEngineConfiguration" class="org.activiti.engine.impl.cfg.StandaloneProcessEngineConfiguration">
        <!-- ... -->
        <property name="databaseSchemaUpdate" value="true" />
        <property name="dataSource" ref="dataSource" />
    </bean>

</beans>
Categories
java

Druid Spring Starter

<dependency>
    <groupId>com.alibaba</groupId>
    <artifactId>druid-spring-boot-starter</artifactId>
    <version>1.2.8</version>
</dependency>


自动注入druid datasource 
Categories
lua

lua

一种脚本语言,可以和C相互调用,可以看作C的脚本语言,不需编译,而且有协程概念。

Categories
java

idea 技巧

当命令行过长

在.idea/workspaces.xml中

修改

<component name=”propertiesComponent”>

<properties name=”dynamic.classpath” value=”true” />

</component>

Categories
docker

docker-compose.yml

docker-compose.yml 用来编写docker容器对象的配置

version: '2'
services:
  web:
    image: dockercloud/hello-world
    ports:
      - 8080
    networks:
      - front-tier
      - back-tier
 
  redis:
    image: redis
    links:
      - web
    networks:
      - back-tier
 
  lb:
    image: dockercloud/haproxy
    ports:
      - 80:80
    links:
      - web
    networks:
      - front-tier
      - back-tier
    volumes:
      - /var/run/docker.sock:/var/run/docker.sock
 
networks:
  front-tier:
    driver: bridge
  back-tier:
    driver: bridge

2,image

  image是指定服务的镜像名称或镜像ID。如果镜像在本地不存在,Compose将会尝试拉取镜像。

123services:web:image: hello-world

   3,build

  服务除了可以基于指定的镜像,还可以基于一份Dockerfile,在使用up启动时执行构建任务,构建标签是build,可以指定Dockerfile所在文件夹的路径。Compose将会利用Dockerfile自动构建镜像,然后使用镜像启动服务容器。

1build: /path/to/build/dir

   也可以是相对路径,只要上下文确定就可以读取到Dockerfile。

1build: ./dir

   设定上下文根目录,然后以该目录为准指定Dockerfile。

123build:context: ../dockerfile: path/of/Dockerfile

   build都是一个目录,如果要指定Dockerfile文件需要在build标签的子级标签中使用dockerfile标签指定。
如果同时指定image和build两个标签,那么Compose会构建镜像并且把镜像命名为image值指定的名字。

  4,context

  context选项可以是Dockerfile的文件路径,也可以是到链接到git仓库的url,当提供的值是相对路径时,被解析为相对于撰写文件的路径,此目录也是发送到Docker守护进程的context

12build:context: ./dir

   5,dockerfile

  使用dockerfile文件来构建,必须指定构建路径

123build:context: .dockerfile: Dockerfile-alternate

   6,commond

  使用command可以覆盖容器启动后默认执行的命令。

1command: bundle exec thin -p 3000

   7,container_name

  Compose的容器名称格式是:<项目名称><服务名称><序号>
可以自定义项目名称、服务名称,但如果想完全控制容器的命名,可以使用标签指定:

1container_name: app

   8,depends_on

在使用Compose时,最大的好处就是少打启动命令,但一般项目容器启动的顺序是有要求的,如果直接从上到下启动容器,必然会因为容器依赖问题而启动失败。例如在没启动数据库容器的时候启动应用容器,应用容器会因为找不到数据库而退出。depends_on标签用于解决容器的依赖、启动先后的问题

1234567891011version: '2'services:web:build: .depends_on:- db- redisredis:image: redisdb:image: postgres

   上述YAML文件定义的容器会先启动redis和db两个服务,最后才启动web 服务。

  9,PID

  pid: "host"
  将PID模式设置为主机PID模式,跟主机系统共享进程命名空间。容器使用pid标签将能够访问和操纵其他容器和宿主机的名称空间。

  10,ports

  ports用于映射端口的标签。
  使用HOST:CONTAINER格式或者只是指定容器的端口,宿主机会随机映射端口。

12345ports:"3000""8000:8000""49100:22""127.0.0.1:8001:8001"

   当使用HOST:CONTAINER格式来映射端口时,如果使用的容器端口小于60可能会得到错误得结果,因为YAML将会解析xx:yy这种数字格式为60进制。所以建议采用字符串格式。

  11,extra_hosts

  添加主机名的标签,会在/etc/hosts文件中添加一些记录。

123extra_hosts:"somehost:162.242.195.82""otherhost:50.31.209.229"

   启动后查看容器内部hosts:

12162.242.195.82  somehost50.31.209.229   otherhost

   12,volumes

  挂载一个目录或者一个已存在的数据卷容器,可以直接使用 [HOST:CONTAINER]格式,或者使用[HOST:CONTAINER:ro]格式,后者对于容器来说,数据卷是只读的,可以有效保护宿主机的文件系统。
Compose的数据卷指定路径可以是相对路径,使用 . 或者 .. 来指定相对目录。
数据卷的格式可以是下面多种形式

1234567891011volumes:// 只是指定一个路径,Docker 会自动在创建一个数据卷(这个路径是容器内部的)。/var/lib/mysql// 使用绝对路径挂载数据卷/opt/data:/var/lib/mysql// 以 Compose 配置文件为中心的相对路径作为数据卷挂载到容器。- ./cache:/tmp/cache// 使用用户的相对路径(~/ 表示的目录是 /home/<用户目录>/ 或者 /root/)。- ~/configs:/etc/configs/:ro// 已经存在的命名的数据卷。- datavolume:/var/lib/mysql

   如果不使用宿主机的路径,可以指定一个volume_driver。
  volume_driver: mydriver

  13,volumes_from

  从另一个服务或容器挂载其数据卷:

123volumes_from:- service_name   - container_name

   14,dns

  自定义DNS服务器。可以是一个值,也可以是一个列表。

1234dns:8.8.8.8dns:- 8.8.8.8   - 9.9.9.9

   15,expose

  暴露端口,但不映射到宿主机,只允许能被连接的服务访问。仅可以指定内部端口为参数,如下所示:

123expose:"3000""8000"

   16,links

  链接到其它服务中的容器。使用服务名称(同时作为别名),或者“服务名称:服务别名”(如 SERVICE:ALIAS),例如:

1234links:- db- db:database- redis

   17,net

  设置网络模式。

123net: "bridge"net: "none"net: "host"

example

version: '2'
services:
  web1:
    image: nginx
    ports:
      - "6061:80"
    container_name: "web1"
    networks:
      - dev
  web2:
    image: nginx
    ports:
      - "6062:80"
    container_name: "web2"
    networks:
      - dev
      - pro
  web3:
    image: nginx
    ports:
      - "6063:80"
    container_name: "web3"
    networks:
      - pro
 
networks:
  dev:
    driver: bridge
  pro:
    driver: bridge
Categories
docker

docker compose

docker-compose 您可以使用 YML 文件来配置应用程序需要的所有服务。然后,使用一个命令,就可以从 YML 文件配置中创建并启动所有服务。

docker-compose up -d

以daemon 方式启动 当前目录下 docker-compose.yml 指定的服务

  1,Docker-compose命令格式

1docker-compose [-f <arg>...] [options] [COMMAND] [ARGS...]

   命令选项如下

12345-f --file FILE指定Compose模板文件,默认为docker-compose.yml-p --project-name NAME 指定项目名称,默认使用当前所在目录为项目名--verbose  输出更多调试信息-v,-version 打印版本并退出--log-level LEVEL 定义日志等级(DEBUG, INFO, WARNING, ERROR, CRITICAL)

   2,docker-compose up

123456789101112docker-compose up [options] [--scale SERVICE=NUM...] [SERVICE...]选项包括:-d 在后台运行服务容器-no-color 不是有颜色来区分不同的服务的控制输出-no-deps 不启动服务所链接的容器--force-recreate 强制重新创建容器,不能与-no-recreate同时使用–no-recreate 如果容器已经存在,则不重新创建,不能与–force-recreate同时使用–no-build 不自动构建缺失的服务镜像–build 在启动容器前构建服务镜像–abort-on-container-exit 停止所有容器,如果任何一个容器被停止,不能与-d同时使用-t, –timeout TIMEOUT 停止容器时候的超时(默认为10秒)–remove-orphans 删除服务中没有在compose文件中定义的容器

   3,docker-compose ps

12docker-compose  ps [options] [SERVICE...]列出项目中所有的容器

   4,docker-compose stop

12345docker-compose stop [options] [SERVICE...]选项包括-t, –timeout TIMEOUT 停止容器时候的超时(默认为10秒)docker-compose stop停止正在运行的容器,可以通过docker-compose start 再次启动

   5,docker-compose -h

12docker-compose -h查看帮助

   6,docker-compose down

12345678docker-compose down [options]停止和删除容器、网络、卷、镜像。选项包括:–rmi type,删除镜像,类型必须是:all,删除compose文件中定义的所有镜像;local,删除镜像名为空的镜像-v, –volumes,删除已经在compose文件中定义的和匿名的附在容器上的数据卷–remove-orphans,删除服务中没有在compose中定义的容器docker-compose down停用移除所有容器以及网络相关

   7,docker-compose logs

12345docker-compose logs [options] [SERVICE...]查看服务容器的输出。默认情况下,docker-compose将对不同的服务输出使用不同的颜色来区分。可以通过–no-color来关闭颜色。docker-compose logs查看服务容器的输出-f 跟踪日志输出

   8,docker-compose bulid

12345678910docker-compose build [options] [--build-arg key=val...] [SERVICE...]构建(重新构建)项目中的服务容器。选项包括:–compress 通过gzip压缩构建上下环境–force-rm 删除构建过程中的临时容器–no-cache 构建镜像过程中不使用缓存–pull 始终尝试通过拉取操作来获取更新版本的镜像-m, –memory MEM为构建的容器设置内存大小–build-arg key=val为服务设置build-time变量服务容器一旦构建后,将会带上一个标记名。可以随时在项目目录下运行docker-compose build来重新构建服务

   9,docker-compose pull

12345678docker-compose pull [options] [SERVICE...]拉取服务依赖的镜像。选项包括:–ignore-pull-failures,忽略拉取镜像过程中的错误–parallel,多个镜像同时拉取–quiet,拉取镜像过程中不打印进度信息docker-compose pull拉取服务依赖的镜像

   10,docker-compose restart

123456docker-compose restart [options] [SERVICE...]重启项目中的服务。选项包括:-t, –timeout TIMEOUT,指定重启前停止容器的超时(默认为10秒)docker-compose restart重启项目中的服务

   11,docker-compose rm

1234567docker-compose rm [options] [SERVICE...]删除所有(停止状态的)服务容器。选项包括:–f, –force,强制直接删除,包括非停止状态的容器-v,删除容器所挂载的数据卷docker-compose rm删除所有(停止状态的)服务容器。推荐先执行docker-compose stop命令来停止容器。

   12,docker-compose start

123docker-compose start [SERVICE...]docker-compose start启动已经存在的服务容器。

   13,docker-compose run

1234docker-compose run [options] [-v VOLUME...] [-p PORT...] [-e KEY=VAL...] SERVICE [COMMAND] [ARGS...]在指定服务上执行一个命令。docker-compose run ubuntu ping www.baidu.com在指定容器上执行一个ping命令。

   14,docker-compose scale

12docker-compose scale web=3 db=2设置指定服务运行的容器个数。通过service=num的参数来设置数量

   15,docker-compose pause

12docker-compose pause [SERVICE...]暂停一个服务容器

   16,docker-compose kill

1234docker-compose kill [options] [SERVICE...]通过发送SIGKILL信号来强制停止服务容器。支持通过-s参数来指定发送的信号,例如通过如下指令发送SIGINT信号:docker-compose kill -s SIGINT

   17,docker-compose config

1234567docker-compose config [options]验证并查看compose文件配置。选项包括:–resolve-image-digests 将镜像标签标记为摘要-q, –quiet 只验证配置,不输出。 当配置正确时,不输出任何内容,当文件配置错误,输出错误信息–services 打印服务名,一行一个–volumes 打印数据卷名,一行一个

   18,docker-compose create

1234567docker-compose create [options] [SERVICE...]为服务创建容器。选项包括:–force-recreate:重新创建容器,即使配置和镜像没有改变,不兼容–no-recreate参数–no-recreate:如果容器已经存在,不需要重新创建,不兼容–force-recreate参数–no-build:不创建镜像,即使缺失–build:创建容器前  ,生成镜像

   19,docker-compose exec

1234567docker-compose exec [options] SERVICE COMMAND [ARGS...]选项包括:-d 分离模式,后台运行命令。–privileged 获取特权。–user USER 指定运行的用户。-T 禁用分配TTY,默认docker-compose exec分配TTY。–index=index,当一个服务拥有多个容器时,可通过该参数登陆到该服务下的任何服务,例如:docker-compose exec –index=1 web /bin/bash ,web服务中包含多个容器

   20,docker-compose port

12345docker-compose port [options] SERVICE PRIVATE_PORT显示某个容器端口所映射的公共端口。选项包括:–protocol=proto,指定端口协议,TCP(默认值)或者UDP–index=index,如果同意服务存在多个容器,指定命令对象容器的序号(默认为1)

   21,docker-compose push

1234docker-compose push [options] [SERVICE...]推送服务依的镜像。选项包括:–ignore-push-failures 忽略推送镜像过程中的错误

   22,docker-compose stop

12docker-compose stop [options] [SERVICE...]停止运行的容器

   23,docker-compose uppause

12docker-compose unpause [SERVICE...]恢复处于暂停状态中的服务。
Categories
java

spring cloud gateway

spring cloud gateway 是微服务常用网关

网关转发语法

application.properties


spring.cloud.gateway.routes[0].id=url-proxy
spring.cloud.gateway.routes[0].predicates[0]=Path=/**
spring.cloud.gateway.routes[0].uri=http://www.baidu.com
spring.cloud.gateway.routes[0].order=1000000



spring.cloud.gateway.routes[1].id=eureka
spring.cloud.gateway.routes[1].predicates[0]=Host=eureka.robinluo.top
spring.cloud.gateway.routes[1].uri=http://localhost:8765
spring.cloud.gateway.routes[1].order=10000

order 越小 优先级越大

predicates 语法:

After=2018-01-20T06:06:06+08:00[Asia/Shanghai]

请求时间过滤 之后

Before=2018-01-20T06:06:06+08:00[Asia/Shanghai]

请求时间过滤 之前

Between=2018-01-20T06:06:06+08:00[Asia/Shanghai], 2019-01-20T06:06:06+08:00[Asia/Shanghai]

请求时间之间

Cookie=ityouknow, kee.e

cookie 匹配

Header=X-Request-Id, \d+

header 匹配

Host=**.ityouknow.com

域名匹配

Method=GET

请求方式匹配

Path=/foo/{segment}

访问路径匹配

Query=smile

请求参数匹配

RemoteAddr=192.168.1.1/24

ip地址匹配

代码分析

所有predicate 都是继承自org.springframework.cloud.gateway.handler.predicate.RoutePredicateFactory 接口的实现类

After = AfterRoutePredicateFactory

Before = BeforeRoutePredicateFactory

Between = BetweenRoutePredicateFactory

Cookie = CookieRoutePredicateFactory

Header = HeaderRoutePredicateFactory

Host = HostRoutePredicateFactory

Method = MethodRoutePredicateFactory

Path = PathRoutePredicateFactory

ReadBody = ReadBodyRoutePredicateFactory

Query = QueryRoutePredicateFactory

RemoteAddr = RemoteAddrRoutePredicateFactory

Weight = WeightRoutePredicateFactory

PredicateSpec 有所有配置语法

Categories
nodejs

gitbook

npm gitbook 文档编辑生成器

first step : npm install -g gitbook-cli

second step : gitbook init

third step: gitbook serve (and your application is running on port 4000)

Categories
uml

uml class diagram

可用的元素声明

abstract abstract

abstract class “abstract class”

annotation annotation

circle circle

class class

diamond diamond

entity entity

enum enum

interface interface

类实体关系

Type Symbol

Extension(扩展) <|–

Composition(组合) *–

Aggregation(聚合) o–

也可以使用 extends implement

定义属性与方法

Object : equals()
ArrayList : Object[] elementData
ArrayList : size()

通过 类对象 : 方法 / 属性 定义

也可以

class

{

嵌套在类

Object[] elementData
int size()

返回属性后置

flightNumber : Integer
departureTime : Date

强制声明为field 或 method 否则根据 是否有括号判断

{field} A field
{method} Some method

}

可访问性

Character Icon for field Icon for method Visibility

-private

#protected

~ package private

+public

抽象与静态

@startuml
class Dummy {
{static} String id
{abstract} void methods()
}
@enduml

Categories
uml

plantuml

plantuml 是uml 的其中一种标准和实现形式

其代码逻辑实现由java 通过正则表达式 逐行逐行 解析uml文本

然后 生成uml的数据结构 实体的结构 关联结构 等。

具体 命令行用法

java -jar pantuml.jar XXX.puml -o XXX.png

可以把XXX.puml 转化为 png的可视化关联对象图片

以@startuml @enduml 包裹 uml代码

@startuml

开始uml

@enduml

结束uml

!inlcude $umlfile

包含/嵌套 其他uml文件

title $title

定义 uml title

title

end title

定义多行title

定义实体后 as 可以起别名