瞎折腾 腾讯云轻量服务器定时创建快照
买了腾讯无忧服务器以后,国内服务器也就基本使用腾讯云了。最近想着既然腾讯云有快照功能,那为什么不利用起来,当作给服务器进行数据备份。 但是每天手动操作又太麻烦,于是想利用腾讯云的 api 创建定时任务,每天自动创建快照。 使用方式如下: 获取腾讯云密钥 地址:https://console.cloud.tencent.com/cam/capi 获取实例id 地址:https://console.c…
经验教程 APScheduler 官方文档
安装 APScheduler $ pip install apscheduler 快速开始 from apscheduler.schedulers.blocking import BlockingScheduler scheduler = BlockingScheduler() @scheduler.scheduled_job('cron', hour='8-23&#…
程序开发 可重入锁 ReentrantLock 使用
ReentrantLock(可重入锁)是 Java 中的一种同步机制,它提供了与synchronized关键字相似的功能,但具有更灵活的特性。在多线程编程中,ReentrantLock允许线程在获取锁之后再次获取同一把锁,而不会导致死锁。 ReentrantLock 具有以下特点: 可重入性: ReentrantLock是可重入的,这意味着一个线程可以多次获取同一把锁而不会产生死锁。当线程重复获取…
经验教程 Mysql 中几种索引失效场景分析
表结构以及数据: CREATE TABLE `t1` ( `a` INT PRIMARY KEY, `b` INT, `c` INT, `d` INT, `e` VARCHAR(20) ) ENGINE=InnoDB; CREATE INDEX idx_bcd ON `t1` (`b`, `c`, `d`); CREATE INDEX idx_e ON `t1` (`e`); insert int…
程序开发 Java 类的生命周期
一个类完整的生命周期,会经历五个阶段,分别为:加载、连接、初始化、使用、和卸载。其中的连接又分为验证、准备和解析三个步骤。如下图所示: 1. 加载(Loading) 简单一句话概括,类的加载阶段就是:找到需要加载的类并把类的信息加载到 jvm 的方法区中,然后在堆区中实例化一个 java.lang.Class 对象,作为方法区中这个类的信息的入口。结合 jvm 的内存结构会比较好理解。 这里的加载…
程序开发 Java 中 volatile 关键字
并发编程中,有三个非常重要的概念: 原子性:提供了一种互斥访问,同一时刻只能有一个线程对它进行操作 可见性:一个线程对主内存对修改可以及时的被其他线程观察到 有序性:一个线程观察其他线程的指令行执行顺序,由于指令重新排序的存在,该观察结果一般杂乱无序 而 volatile 关键字能够保证以下两点: 可见性(Visibility): 当一个线程修改了一个volatile变量的值时,这个新值会立即被写…
程序开发 Java 值传递与引用传递
Java 中方法调用参数传递类型无非两种,一种是基本数据类型、另一种是引用数据类型。受到这两种数据类型的影响,让人误以为,参数传递方式是和数据类型有关的,其实不然。无论是基本数据类型还是引用数据类型。下面我将分类阐述基本类型变量,与引用类型变量传递过程。 基本数据类型传递 public class Test1 { public static void main(String[] args) { T…
程序开发 Axios 基本使用教程
1. 简介 Axios 是一个基于 promise 的网络请求库,作用于 node.js 和浏览器中。它提供了许多强大的特性,比如拦截器、请求和响应转换、取消请求等。 具有如下特性: 从浏览器发出 XMLHttpRequests 从 node.js 发出 http 请求 支持 Promise API 拦截请求和响应 转换请求和响应数据 取消请求 JSON 数据的自动转换 自动将数据对象序列化为正文…
程序开发 Promise 简介以及使用教程
1. 回调地狱 要了解 Promise 是什么,首先要知道什么是异步编程,常见的异步编程有以下几种: nodejs 中 fs 模块操作磁盘文件 数据库操作 ajax 请求 定时器 要知道,js 设计之初就是单线程模式,那么遇到异步函数不能等它执行完再执行,所以通常传递一个回调函数。例如: setTimeout(() => { console.log('3 秒后打印'); …
程序开发 Vue-router 使用教程
1. 简介 vue-router 是官方提供的路由插件。Vue 中的路由其实就是路径和组件之间的对应关系,因为 vue 是单页应用类网站,所以创建的网站都在一个页面中。当需要展示不同的内容时,就需要通过修改浏览器的访问路径,来达到根据路径展示不同组件的目的。 官方文档:https://router.vuejs.org/zh/ 可以使用 <router-link> 组件进行导航,使用 &…