安全设置
Mycat作为一个连接数据库的中间件,距离数据是非常的近,所以还是需要进行一些安全的设置
权限控制
在server.xml中配置user标签进行权限控制
1 | <!-- 用户 --> |
sql拦截
除了上述介绍的Mycat可以进行权限控制,还可以使用防火墙进行ip、sql的控制,server.xml配置文件中使用firewall来定义防火墙
1 | <!-- 全局SQL防火墙设置 --> |
黑名单配置项说明
| 配置项 | 缺省值 | 描述 |
|---|---|---|
| selelctAllow | true | 是否允许执行SELECT语句 |
| selectAllColumnAllow | true | 是否允许执行SELECT FROM T这样的语句。如果设置为false,不允许执行select from t,这个选项是防御程序通过调用select *获得数据表的结构信息。 |
| selectIntoAllow | true | SELECT查询中是否允许INTO字句 |
| deleteAllow | true | 是否允许执行DELETE语句 |
| updateAllow | true | 是否允许执行UPDATE语句 |
| insertAllow | true | 是否允许执行INSERT语句 |
| replaceAllow | true | 是否允许执行REPLACE语句 |
| mergeAllow | true | 是否允许执行MERGE语句,这个只在Oracle中有用 |
| callAllow | true | 是否允许通过jdbc的call语法调用存储过程 |
| setAllow | true | 是否允许使用SET语法 |
| truncateAllow | true | truncate语句是危险,缺省打开,若需要自行关闭 |
| createTableAllow | true | 是否允许创建表 |
| alterTableAllow | true | 是否允许执行Alter Table语句 |
| dropTableAllow | true | 是否允许修改表 |
| commentAllow | false | 是否允许语句中存在注释,Oracle的用户不用担心,Wall能够识别hints和注释的区别 |
| noneBaseStatementAllow | false | 是否允许非以上基本语句的其他语句,缺省关闭,通过这个选项就能够屏蔽DDL |
| multiStatementAllow | false | 是否允许一次执行多条语句,缺省关闭 |
| useAllow | true | 是否允许执行mysql的use语句,缺省打开 |
| describeAllow | true | 是否允许执行mysql的describe语句,缺省打开 |
| showAllow | true | 是否允许执行mysql的show语句,缺省打开 |
| commitAllow | true | 是否允许执行commit操作 |
| rollbackAllow | true | 是否允许执行roll back操作 |