php opcache

让PHP7达到最高性能的几个Tips   http://www.laruence.com/2015/12/04/3086.html

开启opcache前后对比 cpu运算时间减少,内存使用减少

opcache_reset();  //清除opcache缓存

opcache_compile_file(‘test2.php’); //缓存某个文件

opcache_invalidate(‘test2.php’, true) //清除某个文件缓存

opcache_is_script_cached(‘test2.php’) //查看文件是否缓存返回true/false

opcache_get_status();获取缓存的状态信息

opcache_get_configuration(); 获取缓存的配置信息

[opcache]
zend_extension = "G:/PHP/php-5.5.6-Win32-VC11-x64/ext/php_opcache.dll"
 
; Zend Optimizer + 的开关, 关闭时代码不再优化.
opcache.enable=1
 
; Determines if Zend OPCache is enabled for the CLI version of PHP
opcache.enable_cli=1
 
 
; Zend Optimizer + 共享内存的大小, 总共能够存储多少预编译的 PHP 代码(单位:MB)
; 推荐 128
opcache.memory_consumption=64
 
; Zend Optimizer + 暂存池中字符串的占内存总量.(单位:MB)
; 推荐 8
opcache.interned_strings_buffer=4
 
 
; 最大缓存的文件数目 200  到 100000 之间
; 推荐 4000
opcache.max_accelerated_files=2000
 
; 内存“浪费”达到此值对应的百分比,就会发起一个重启调度.
opcache.max_wasted_percentage=5
 
; 开启这条指令, Zend Optimizer + 会自动将当前工作目录的名字追加到脚本键上,
; 以此消除同名文件间的键值命名冲突.关闭这条指令会提升性能,
; 但是会对已存在的应用造成破坏.
opcache.use_cwd=0
 
 
; 开启文件时间戳验证 
opcache.validate_timestamps=1
 
 
; 2s检查一次文件更新 注意:0是一直检查不是关闭
; 推荐 60
opcache.revalidate_freq=2
 
; 允许或禁止在 include_path 中进行文件搜索的优化
;opcache.revalidate_path=0
 
 
; 是否保存文件/函数的注释   如果apigen、Doctrine、 ZF2、 PHPUnit需要文件注释
; 推荐 0
opcache.save_comments=1
 
; 是否加载文件/函数的注释
;opcache.load_comments=1
 
 
; 打开快速关闭, 打开这个在PHP Request Shutdown的时候会收内存的速度会提高
; 推荐 1
opcache.fast_shutdown=1
 
;允许覆盖文件存在(file_exists等)的优化特性。
;opcache.enable_file_override=0
 
 
; 定义启动多少个优化过程
;opcache.optimization_level=0xffffffff
 
 
; 启用此Hack可以暂时性的解决”can’t redeclare class”错误.
;opcache.inherited_hack=1
 
; 启用此Hack可以暂时性的解决”can’t redeclare class”错误.
;opcache.dups_fix=0
 
; 设置不缓存的黑名单
; 不缓存指定目录下cache_开头的PHP文件. /png/www/example.com/public_html/cache/cache_ 
;opcache.blacklist_filename=
 
 
; 通过文件大小屏除大文件的缓存.默认情况下所有的文件都会被缓存.
;opcache.max_file_size=0
 
; 每 N 次请求检查一次缓存校验.默认值0表示检查被禁用了.
; 由于计算校验值有损性能,这个指令应当紧紧在开发调试的时候开启.
;opcache.consistency_checks=0
 
; 从缓存不被访问后,等待多久后(单位为秒)调度重启
;opcache.force_restart_timeout=180
 
; 错误日志文件名.留空表示使用标准错误输出(stderr).
;opcache.error_log=
 
 
; 将错误信息写入到服务器(Apache等)日志
;opcache.log_verbosity_level=1
 
; 内存共享的首选后台.留空则是让系统选择.
;opcache.preferred_memory_model=
 
; 防止共享内存在脚本执行期间被意外写入, 仅用于内部调试.
;opcache.protect_memory=0

 

spring boot idea 热部署不生效 devtools

解决 devtools 不生效

  • 检查依赖
<dependency>
	<groupId>org.springframework.boot</groupId>
	<artifactId>spring-boot-devtools</artifactId>
	<optional>true</optional>
</dependency>
  • IDEA工具启动自动编译功能

  • IDEA 设置为在程序运行过程中,依然允许自动编译 操作: ctrl + shift + alt + /,选择Registry,勾选勾上 Compiler autoMake allow when app running

spring boot task

任务

定时任务

  • 开启 @EnableScheduling 注解
@SpringBootApplication
@EnableScheduling
public class ExampleApplication {

    public static void main(String[] args) {
        SpringApplication.run(ExampleApplication.class, args);
    }
}
  • 定义任务类 启用 @Component @Scheduled 注解 (cron 写法参考linux crontab)
import org.springframework.scheduling.annotation.Scheduled;
import org.springframework.stereotype.Component;

@Component
public class CronTask {
    
    //每过5秒执行一次 
    @Scheduled(cron = "0/5 * * * * *")
    public void hello(){
        System.out.println("hello!");
    }
}

异步任务

  • 增加 @EnableAsync 注解开启异步支持
@SpringBootApplication
@EnableScheduling
@EnableAsync
public class ExampleApplication {

	public static void main(String[] args) {
		SpringApplication.run(ExampleApplication.class, args);
	}
}
  • 编写异步任务 增加 @Component @Async 注解
import org.springframework.scheduling.annotation.Async;
import org.springframework.stereotype.Component;

@Component
public class AsyncTask {
    @Async
    public void async1(){
        try{
            Thread.sleep(1000);
        }catch (Exception e){

        }
    }
    @Async
    public void async2(){
        try{
            Thread.sleep(700);
        }catch (Exception e){

        }
    }

    @Async
    public void async3(){
        try{
            Thread.sleep(500);
        }catch (Exception e){

        }
    }

}

mongodb 语法

1.查看数据库列表  show dbs

2.切换数据库 (mongodb会在需要的时候自动创建数据库)

3.删除数据库

4.插入数据  db.{数据表名}.insert()

5.查询 db.{数据表名}.find(查询条件)     findOne  查询单条

6.统计符合结果集的条数 db.{数据表名}.count()

7.连贯操作

db.test_collection.find().limit(4).sort({“name”:1}).skip(2)

查询 test_collection 表 结果集限制输出4条  按照 name 属性排序   跳过前两 2条

8.更新操作 db.test_collection.update(更新条件,更新的结果数据,true)

第三个参数  表示更新条件的数据不存在时自动插入一条

第四个参数表示是否更新所有满足条件的行

db.test_collection.update({“name”:1},{$set:”name”:666})     加上参数只更新指定的参数

8.删除指定的数据

9.查看表 show tables  删除表 db.{表名}.drop()

10.查看表拥有的索引 db.{表名}.getIndexes()

11.创建索引  db.{表名}.ensureIndex(“name”:1)  1 为正序 -1 为倒序

linux shell script

#!/bin/bash  
############################
#desc:这只是练习案例
############################

read -t 10 -p '请输入你的名字: ' name;  #name变量提示用户输入,用户10秒未      输入结束

name=${name:- 'ace'}; #当name未定义时默认值为ace

1.判断

-e : 该文件名是否存在(目录或文件)

-f : 该文件是否存在

-d : 该目录是否存在

-r : 该文件是否具有读权限

-w : 该文件是否具有写权限

-x : 该文件是否具有执行权限

-eq : 两个值是否相等

-gt -lt : 大于,小于

== : 判断两个字符串是否相等

-a : and 相当于 &&

-o : or 相当于 ||

-! :  取反