数据库并发操作会带来哪些问题及原因

理解 MySQL 中的四种隔离级别

隔离级别

  • 数据库事务有不同的隔离级别,不同的隔离级别对锁的使用是不同的,锁的应用最终导致不同事务的隔离级别。
  • 实现隔离级别的方式就是加锁

隔离级别的分类

  1. 读未提交 Read Uncommitted(在本次事务中可以读到其他事务中没有提交的数据 - 脏数据)
  2. 读已提交 Read Committed (只能读到其他事务提交过的数据。如果在当前事务中,其他事务有提交,则两次读取结果不同)
  3. 可重复读 Repeatable Read (默认,保证了事务中每次读取结果都相同,而不管其他事物是否已经提交。会出现幻读)
  4. 序列化 Serializable (隔离级别中最严格的,开启一个 serializable 事务,那么其他事务对数据表的写操作都会被挂起)

- 阅读剩余部分 -

数据库并发的五个问题以及四级封锁协议与事务隔离的四个级别

五类并发问题

丢失更新(第一类丢失更新)

撤销一个事务时,把其他事务已提交的更新数据覆盖(A和B事务并发执行,A事务执行更新后,提交;B事务在A事务更新后,B事务结束前也做了对该行数据的更新操作,然后回滚,则两次更新操作都丢失了)。这种并发问题是由于完全没有隔离事务造成的。只要设置隔离级别,数据库就能保证此类问题不发生。

- 阅读剩余部分 -

网站出现502 BAD GATEWAY的解决办法

出现502 bad gateway错误的原因

1.php-fpm进程数不够用
2.Linux内核打开文件数量小
3.脚本执行时间超时
4.缓存设置比较小

网站间歇性出现502,第一反应不是程序的问题,而是nginx服务器的问题,因为这是代理服务器出现的问题,代理服务器并没有安装php 排除第一中情况。

于此想到的是可能是超时,所以我把超时修改了一些
一下是服务器原配置(重点配置)

- 阅读剩余部分 -

什么是脚本语言?

脚本语言又被称为扩建的语言,或者动态语言,是一种编程语言,用来控制软件应用程序,脚本通常以文本(如ASCII)保存,只在被调用时进行解释或编译。
中文名 脚本语言 外文名 Scripting language 别 名 动态语言 类 别 编程语言

概述定义
脚本语言(Script languages,scripting programming languages,scripting languages)是为了缩短传统的编写-编译-链接-运行(edit-compile-link-run)过程而创建的计算机编程语言。此命名起源于一个脚本“screenplay”,每次运行都会使对话框逐字重复。早期的脚本语言经常被称为批处理语言或工作控制语言。一个脚本通常是解释运行而非编译。虽然许多脚本语言都超越了计算机简单任务自动化的领域,成熟到可以编写精巧的程序,但仍然还是被称为脚本。几乎所有计算机系统的各个层次都有一种脚本语言。包括操作系统层,如计算机游戏,网络应用程序,文字处理文档,网络软件等。在许多方面,高级编程语言和脚本语言之间互相交叉,二者之间没有明确的界限。一个脚本可以使得本来要用键盘进行的相互式操作自动化。一个Shell脚本主要由原本需要在命令行输入的命令组成,或在一个文本编辑器中,用户可以使用脚本来把一些常用的操作组合成一组序列。主要用来书写这种脚本的语言叫做脚本语言。很多脚本语言实际上已经超过简单的用户命令序列的指令,还可以编写更复杂的程序。
简介
脚本语言是为了缩短传统的编写-编译-链接-运行(edit-compile-link-run)过程而创建的计算机编程语言。 它的命名起源于一个脚本“screenplay”,每次运行都会使对话框逐字重复。早期的脚本语言经常被称为批量处理语言或工作控制语言。
一个脚本通常是解释执行而非编译。脚本语言通常都有简单、易学、易用的特性,目的就是希望能让程序员快速完成程序的编写工作。而宏语言则可视为脚本语言的分支,两者也有实质上的相同之处。

- 阅读剩余部分 -

我的 atom 开发工具

不知不觉折腾 Atom 已经两个星期了,主要被他漂亮简介的主题所吸引,还有会震动的效果。

下面我详细介绍下我的 Atom 插件配置和说明

Community Packages (19) C:\Users\Slagga\.atom\packages
├── activate-power-mode@2.0.0
├── atom-autocomplete-php@0.25.6
├── atom-beautify@0.29.26
├── atom-file-types@0.5.5
├── atom-goto-definition@1.3.3
├── atom-php-cs-fixer@4.1.0
├── atom-quick-highlight@0.10.0
├── autocomplete-paths@1.0.5
├── busy-signal@1.4.3
├── emmet-atom@2.4.3
├── file-type-icons@1.3.4
├── goto@1.8.3
├── intentions@1.1.2
├── linter@2.1.4
├── linter-php@1.3.2
├── minimap@4.28.2
├── minimap-find-and-replace@4.5.2
└── php-class-tree@1.0.0

- 阅读剩余部分 -