云溪的 blog
  • Archive
  • Media
  • Search
  • Tags
  • About
Home

Posts

编译安装php常见问题

configure: error: libxml2 not found. 详细错误如下: configure: error: libxml2 not found. Please check your libxml2 installation. make: *** No targets specified and no makefile found. Stop. make: *** No rule to make target 'install'. Stop. 解决方法: $ sudo apt-get install libxml2-dev configure: error: png.h not found. 详细错误如下: configure: error: png.h not found. make: *** No targets specified and no makefile found. Stop. make: *** No rule to make target 'install'. Stop. 解决方法: $ sudo apt-get install libpng-dev configure: error: freetype-config not found. 详细错误如下: ...

February 24, 2019 · 1 min · 云溪

virtualbox 分享文件夹,无权访问问题

背景 在 windows 下使用 virtualbox 安装 linux 系统 实现 windows 下开发虚拟机里跑测试的效果 起因 由于项目使用文件目录是可以在 windows 和 linux 下共享的,因此使用 virtualbox 共享文件夹功能来实现项目文件夹在两个系统间共享,配置好共享文件后,发现在虚拟机的 linux 系统中没有权限操作目录. 百度之后发现原来是因为共享文件夹挂在后的文件是属于 vboxsf 组下的,而登陆用户不属于该组,因而无权对目录进行操作。 解决方法 既然知道原因,解决办法也是非常简单的就是将当前登录的用户加入 vboxsf 用户组即可: $ sudo usermod -aG vboxsf $(whoami) 需要注意的是该操作需要重启系统才能生效。

February 24, 2019 · 1 min · 云溪

gorm常见问题

sql: Scan error on column index 5, name “created_at”: unsupported Scan, storing driver.Value type []uint8 into type *time.Time DATETIME转换问题 执行Rows.Scan()时报告错误 原因是在调用sql.Open()时没有将parseTime设置为True。加入parseTime即可修复问题: db, err := sql.Open("mysql", "user:password@tcp(127.0.0.1:3306)/dbname?parseTime=true") invalid memory address or nil pointer dereference on simple learning example. Maybe a bug with latest version 代码实例 package main import ( "net/http" "strconv" "github.com/gin-gonic/gin" "github.com/jinzhu/gorm" _ "github.com/jinzhu/gorm/dialects/postgres" ) var db *gorm.DB func init() { var err error db, err := gorm.Open("postgres", "host=localhost user=postgres dbname=postgres sslmode=disable password=pass") if err != nil { panic("failed to connect database") } db.AutoMigrate(&todoModel{}) } 重点在 db, err := gorm.Open("postgres", "host=localhost user=postgres dbname=postgres sslmode=disable password=pass") 代码处,由于上述代码中已经设置了全局变量 db 所以在接受赋值的时候不能用 := 二应该用 = 。 正确代码应该为 db, err := gorm.Open("postgres", "host=localhost user=postgres dbname=postgres sslmode=disable password=pass") ...

December 22, 2018 · 1 min · 云溪

Error 1292: Incorrect datetime value: '0000-00-00' for column 'created_at' at row 1

使用 gorm 插入数据时爆出 Error 1292: Incorrect datetime value: '0000-00-00' for column 'created_at' at row 1 的错误信息,搜索之后发现原来是因为 msyql5.7 及以上不允许时间戳字段插入 ‘0000-00-00’ 数据,修复方法也比较简单,去掉sql_model 中的 NO_ZERO_DATE 配置即可 方式一 sql 配置 使用 select @@GLOBAL.sql_mode; 查出原有的配置信息,将配置信息去除 NO_ZERO_DATE 并复制 使用 SET GLOBAL sql_mode = '去除 NO_ZERO_DATE 后的剩余配置项' 经过以上步骤就可以完成设置了。 方式二 配置文件配置 打开 mysql 配置文件: $ sodo vim /etc/my.cnf 在 [mysqld] 配置项下插入 sql_mode 配置 sql_mode=ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION 重启 mysql 完成配置 sql_model 参数详解 ONLY_FULL_GROUP_BY: 对于GROUP BY聚合操作,如果在SELECT中的列,没有在GROUP BY中出现,那么这个SQL是不合法的,因为列不在GROUP BY从句中 NO_AUTO_VALUE_ON_ZERO: 该值影响自增长列的插入。默认设置下,插入0或NULL代表生成下一个自增长值。如果用户 希望插入的值为0,而该列又是自增长的,那么这个选项就有用了。 STRICT_TRANS_TABLES: 在该模式下,如果一个值不能插入到一个事务表中,则中断当前的操作,对非事务表不做限制 NO_ZERO_IN_DATE: 在严格模式下,不允许日期和月份为零 NO_ZERO_DATE: 设置该值,mysql数据库不允许插入零日期,插入零日期会抛出错误而不是警告。 ERROR_FOR_DIVISION_BY_ZERO: 在INSERT或UPDATE过程中,如果数据被零除,则产生错误而非警告。如 果未给出该模式,那么数据被零除时MySQL返回NULL NO_AUTO_CREATE_USER: 禁止GRANT创建密码为空的用户 NO_ENGINE_SUBSTITUTION: 如果需要的存储引擎被禁用或未编译,那么抛出错误。不设置此值时,用默认的存储引擎替代,并抛出一个异常 PIPES_AS_CONCAT: 将"||"视为字符串的连接操作符而非或运算符,这和Oracle数据库是一样的,也和字符串的拼接函数Concat相类似 ANSI_QUOTES: 启用ANSI_QUOTES后,不能用双引号来引用字符串,因为它被解释为识别符 参考链接 Error 1292 on update a row ...

December 22, 2018 · 1 min · 云溪

Centos 服务配置详解

systemd 介绍 CentOS 7的服务systemctl脚本存放在:/usr/lib/systemd/,有系统(system)和用户(user)之分,即:/usr/lib/systemd/system ,/usr/lib/systemd/user 创建 Service 文件 以 Supervisor 加入服务为例 [Unit] Description=Supervisor [Service] Type=forking ExecStart=/usr/bin/supervisord -c /etc/supervisor/supervisord.conf ExecStop=/usr/bin/supervisorctl shutdown ExecReload=/usr/bin/supervisorctl reload KillMode=process Restart=on-failure RestartSec=42s [Install] WantedBy=multi-user.target 参数介绍 Unit: NAME DESCRIPTION ExecStartPre 在单元(Unit)开始前执行命令 ExecStart 在单元(Unit)开始时执行主命令 ExecStartPost 在 ExecStart 命令执行完毕之后执行 ExecReload 在单元(Unit)Reload 时执行主命令 ExecStop 在单元(Unit) Stop 时执行命令 ExecStopPost 在 ExecStop 配置命令执行完毕后执行 RestartSec 服务重启失败重试间隔时间 Type : 启动类型simple、forking、oneshot、notify、dbus Type=simple(默认值):systemd认为该服务将立即启动。服务进程不会fork。如果该服务要启动其他服务,不要使用此类型启动,除非该服务是socket激活型。 Type=forking:systemd认为当该服务进程fork,且父进程退出后服务启动成功。对于常规的守护进程(daemon),除非你确定此启动方式无法满足需求,使用此类型启动即可。使用此启动类型应同时指定 PIDFile=,以便systemd能够跟踪服务的主进程。 Type=oneshot:这一选项适用于只执行一项任务、随后立即退出的服务。可能需要同时设置 RemainAfterExit=yes 使得 systemd 在服务进程退出之后仍然认为服务处于激活状态。 Type=notify:与 Type=simple 相同,但约定服务会在就绪后向 systemd 发送一个信号。这一通知的实现由 libsystemd-daemon.so 提供。 Type=dbus:若以此方式启动,当指定的 BusName 出现在DBus系统总线上时,systemd认为服务就绪。 ...

December 20, 2018 · 1 min · 云溪
« Prev  Next  »
© 2025 云溪的 blog