JAVA-and-J2EE
ThreadPoolExecutor的详解及自定义阻塞提交的ThreadLocalExcutor实例
星期二, 十一月 2nd, 2021 | JAVA-and-J2EE | 没有评论
ThreadPoolExecutor可以实现线程池的创建。ThreadPoolExecutor相关类图如下:
类图
从类图可以看出,ThreadPoolExecutor最终实现了Executor接口,是线程池创建的真正实现者。
Executor两级调度模型
Executor模型
在HotSpot虚拟机中,Java中的线程将会被一一映射为操作系统的线程。在Java虚拟机层面,用户将多个任务提交给Executor框架,Executor负责分配线程执行它们;在操作系统层面,操作系统再将这些线程分配给处理器执行。
ThreadPoolExecutor的三个角色
任务
ThreadPoolExecutor接受两种类型的任务:Callable和Runnable。
Callable:该类任务有返回结果,可以抛出异常。通过submit方法提交,返回Future对象。通过get获取执行结果。
Runnable:该类任务只执行,无法获取返回结果,在执行过程中无法抛异常。通过execute或submit方法提交。
任务执行器
Executor框架最核心的接口是Executor,它表示任务的执行器。
通过上面类图可以看出,Executor的子接口为ExecutorService。再往底层有两大实现类:ThreadPoolExecutor和ScheduledThreadPoolExecutor(集成自ThreadPoolExecutor)。
执行结果
Future接口表示异步的执行结果,它的实现类为FutureTask。
三个角色之间的处理逻辑图如下:
FutureTask逻辑
线程池处理流程
线程池处理流程
一个线程从被提交(submit)到执行共经历以下流程:
线程池判断核心线程池里是的线程是否都在执行任务,如果不是,则创建一个新的工作线程来执行任务。如果核心线程池里的线程都在执行任务,则进入下一个流程;
线程池判断工作队列是否已满。如果工作队列没有满,则将新提交的任务储存在这个工作队列里。如果工作队列满了,则进入下一个流程;
线程池判断其内部线程是否都处于工作状态。如果没有,则创建一个新的工作线程来执行任务。如果已满了,则交给饱和策略来处理这个任务。
› Continue reading
mac下的VirtualBox安装deepin自定义硬盘大小
星期三, 十月 27th, 2021 | computer, JAVA-and-J2EE, linux | 没有评论
mac下的VirtualBox安装deepin自定义硬盘大小
遇到的一些问题记录下解决过程
0.mac下安装VirtualBox遇到的无法启动问题(6.1.28)
系统偏好设置–》安全性及隐私
通用项目–》运行从以下地址下载的APP 开启任何来源 或者 APPstore和认可的开发者,详情里把 Oracle勾选上去
隐私项目–》辅助功能、完全磁盘访问权限、文件和文件夹 把VirtualBox的完全访问权限加上,其他自选加入不影响
1.下载deepin-desktop-community-20.2.4-amd64.iso文件,初始化硬盘30G大小
遇到全盘安装至少要64G否则无法安装,这里选左侧自定义安装
创建主分区,根目录下,选自动挂载,把30G的硬盘大小拖到最后,貌似至少需要19G。
2.进入不算太漫长的安装等待,一般会在5%的地方等待好久,慢慢等就好了,一般10来分钟即完成安装.
3.安装完成界面很小,不会跟随屏幕自动变大,要安装增强扩展,通过标题栏,一般会报错,找不到对应的iso挂载文件
这里可以看下cd里有没有挂载到VBoxGuestAdditions.iso,没有挂载的话,在cd驱动里选上即可
解决方法:手工挂载执行,找得到文件直接执行即可.
sudo su cd /media mkdir cdrom mount /dev/cdrom /media/cdrom cd cdrom sh VBoxLinuxAdditions.run |
Presto进程管理实现监控及自动重启
星期四, 十月 21st, 2021 | JAVA-and-J2EE, 大数据 | 没有评论
具体搭建就不说了可以参考官方文档
https://prestodb.io/docs/current/
其他查询接口也列下:
默认UI是:根据更改的端口调整
http://xxx:8080
获取集群状态 接口:
http://xxx/v1/cluster
获取NODE信息:接口:
http://xxx/v1/node
访问/v1/info/state, 直接从worker处获取worker的状态
取各节点的版本详情 获取节点信息的接口:
http://xxx/v1/service
具体监控信息如下:
› Continue reading
eclipse2021-06版本使用lombok
星期五, 八月 13th, 2021 | JAVA-and-J2EE | 没有评论
Eclipse IDE for Enterprise Java and Web Developers (includes Incubating components)
Version: 2021-06 (4.20.0)
Build id: 20210612-2011
(c) Copyright Eclipse contributors and others 2000, 2021. All rights reserved. Eclipse and the Eclipse logo are trademarks of the Eclipse Foundation, Inc., https://www.eclipse.org/. The Eclipse logo cannot be altered without Eclipses permission. Eclipse logos are provided for use under the Eclipse logo and trademark guidelines, https://www.eclipse.org/logotm/. Oracle and Java are trademarks or registered trademarks of Oracle and/or its affiliates. Other names may be trademarks of their respective owners.
This product includes software developed by other open source projects including the Apache Software Foundation, https://www.apache.org/.
Lombok v1.18.20 “Envious Ferret” is installed. https://projectlombok.org/
上面是安装完成的版本信息
1.Lombok v1.18.20 下载 当前最新版本 https://projectlombok.org/
2. java -jar lombok.jar
3.安装完毕检查eclipse.ini下配置(需要自行添加–illegal-access=permit)使用jdk16出现的问题
-javaagent:/Applications/Eclipse.app/Contents/Eclipse/lombok.jar --illegal-access=permit |
4.重启eclipse可以正常使用
Elasticsearch技术使用(ES): 索引别名Aliases问题
星期四, 七月 8th, 2021 | JAVA-and-J2EE, 大数据 | 没有评论
业务问题#
业务需求是不断变化迭代的,也许我们之前写的某个业务逻辑在下个版本就变化了,我们可能需要修改原来的设计,例如数据库可能需要添加一个字段或删减一个字段,而在搜索中也会发生这件事,即使你认为现在的索引设计已经很完美了,在生产环境中,还是有可能需要做一些修改的,需要添加映射字段或者需要修改字段类型等等。
数据库中我们可以直接修改原来的表设计语句,前提是需要做好数据迁移。但是在 Elasticsearch 中就没那么简单了。尽管可以增加新的类型到索引中,或者增加新的字段到类型中,但是不能添加新的分析器或者对现有的字段做改动。如果你那么做的话,结果就是那些已经被索引的数据就不正确,搜索也不能正常工作。针对这个问题必须重新建立索引。
别名定义#
重新建立索引的问题是必须更新应用中的索引名称,索引别名就是用来解决这个问题的!
假设我们有个学生的原始索引 student_index_v1,我们给它起个别名 student_index,程序中也是用别名 student_index 进行搜索,当我们的业务需求发生改变需要修改索引的时候,我们重新创建个索引 student_index_v2,同时将别名 student_index 指向新的索引 student_index_v2,同时将 student_index_v1 的数据迁移到新的 student_index_v2,这样我们就可以做到在零停机下从旧索引切换到新索引。
索引别名就像一个快捷方式或软连接,可以指向一个或多个索引,也可以给任何一个需要索引名的API来使用,而且别名不能与索引同名。
别名带给我们极大的灵活性,允许我们做下面这些:
在运行的集群中可以无缝的从一个索引切换到另一个索引。
给多个索引分组。
给索引的一个子集创建视图。
别名管理#
别名还可以映射到某个索引也可以映射到多个索引。别名还可以与筛选器关联,筛选器将在搜索和路由值时自动应用,别名不能与索引同名。
Elasticsearch 中有两种方式管理别名: _alias 用于单个操作, _aliases 用于执行多个原子级操作。
› Continue reading
ssh连接好用的工具electerm或xshell
星期五, 七月 2nd, 2021 | JAVA-and-J2EE, linux, mac, work-other | 没有评论
1.xshell基本上是window下常用的工具了,可以使用家庭版和学校版本免费
家庭或者学校版快速地址:https://www.netsarang.com/zh/free-for-home-school/
2.开源且使用起来还不错的electerm,支持linux, mac, win常用的三端
electerm is a terminal/ssh/sftp client(linux, mac, win) based on electron/ssh2/node-pty/xterm/antd/subx and many other libs.
centos7或者windows下部署gitbook
星期四, 五月 13th, 2021 | JAVA-and-J2EE, linux | 没有评论
1.使用node版本为12版本,14版本会有问题降低版本保平安
node网站地址:https://nodejs.org/en/download/
win下地址:https://nodejs.org/dist/latest-v12.x/node-v12.22.1-x64.msi
linux下的版本: https://nodejs.org/dist/latest-v12.x/node-v12.22.1-linux-x64.tar.xz
2.解压及配置路径
tar -xJf node-v12.22.1-linux-x64.tar.xz -C /usr/local/lib/ cd /usr/local/lib mv node-v12.22.1-linux-x64/ nodejs |
3.配置环境变量
vi /etc/profile export PATH=/usr/local/lib/nodejs/bin:$PATH source /etc/profile |
测试npm命令信息,输入npm -v查看npm的版本
4.利用npm 安装gitbook-cli
npm install -g gitbook-cli |
gitbook –version查看版本信息,执行时会自动安装gitbook
遭遇错误注释掉对应的文件中的 polyfills.js
//fs.stat = statFix(fs.stat) //fs.fstat = statFix(fs.fstat) //fs.lstat = statFix(fs.lstat) |
JAVA使用HikariCP开启执行批量执行插入数据
星期五, 四月 30th, 2021 | JAVA-and-J2EE | 没有评论
1.使用HikariConfig配置如下: 开启批量处理
#mysql config jdbcUrl=jdbc:mysql://localhost:3306/xxx?useUnicode=true&characterEncoding=UTF-8&zeroDateTimeBehavior=convertToNull&useSSL=false&serverTimezone=Asia/Shanghai username=root password=root driverClassName=com.mysql.cj.jdbc.Driver dataSource.cachePrepStmts=true dataSource.prepStmtCacheSize=250 dataSource.prepStmtCacheSqlLimit=2048 dataSource.useServerPrepStmts=true dataSource.useLocalSessionState=true dataSource.rewriteBatchedStatements=true dataSource.cacheResultSetMetadata=true dataSource.statementsPerBatch=5000 #dataSource.cacheServerConfiguration=true #dataSource.elideSetAutoCommits=true dataSource.maintainTimeStats=false dataSource.useCursorFetch=true autoCommit=true maximumPoolSize=10 |
2.使用批量执行语句
String sql ="INSERT INTO MyTable(ColA, ColB, ColC) VALUES (?, ?, ?)"; //ok batch sql ="INSERT INTO MyTable(ColA, ColB, ColC) VALUE (?, ?, ?)"; //no batch only Inserting one record at a time queryRunner.batch(, new Object[][] { {"A1", "B1", "C1"}, {"A2", "B2", "C2"}, {"A3", "B3", "C3"}}); |
小结:因为使用了 VALUE 不是 VALUES而无法批量生效,一直跟踪debug才发现,浪费了半天时间囧.
centos7.x配置安装chrome+chromedriver+selenium
星期四, 十二月 31st, 2020 | JAVA-and-J2EE, linux | 没有评论
1.系统centos7.x
下载chrome
wget https://dl.google.com/linux/direct/google-chrome-stable_current_x86_64.rpm |
2. 安装chrome
yum -y install ./google-chrome-stable_current_x86_64.rpm |
2.1.Installed:
google-chrome-stable.x86_64 0:87.0.4280.88-1
查看chrome版本号
[root@localhost soft]# google-chrome --version Google Chrome 87.0.4280.88 |
3.下载对应的chromedriver(87.0.4280.88)版本要保持一致
wget https://npm.taobao.org/mirrors/chromedriver/87.0.4280.88/chromedriver_linux64.zip #解压chromedriver_linux64.zip unzip chromedriver_linux64.zip mv chromedriver /usr/bin/ |
4. 后续使用selenium等就可以愉快的使用了
5.修复中文方块问题
中文字体问题:下载宋体simsun,或者其他字体
把文件放到
/usr/share/fonts/simsun.ttc ##执行命令 fc-cache -fv |
成功后即可
docker-selenium server的安装及使用
星期二, 十二月 22nd, 2020 | JAVA-and-J2EE, linux | 没有评论
1.需要使用selenium进行访问网站获取信息及截图
在服务器上安装对应的selenium比较麻烦,有docker真是方便多了
更多使用代码见:启用远程调用Docker下应用selenium-chrome服务
2.安装docker,如果已经安装可以忽略
此处选用的是chrome,完成后访问地址:http://localhost:4444/wd/hub
顺便安装下docker的openjdk11为以后备用.
$ curl -sSL https://get.daocloud.io/docker | sh $ sudo systemctl start docker $ docker run -d -p 4444:4444 -v /dev/shm:/dev/shm selenium/standalone-chrome:4.0.0-beta-1-prerelease-20201208 //如果遭遇iptables nat 等失败 可以重新启动下docker再运行selenium chrome解决 $ service iptables stop $ service iptables start $ sudo systemctl restart docker $ docker run -d -p 4444:4444 -v /dev/shm:/dev/shm selenium/standalone-chrome:4.0.0-beta-1-prerelease-20201208 //仅仅是备用,无需安装 $ docker pull openjdk:11 |
3.使用selenium即可
<dependency> <groupId>org.seleniumhq.selenium</groupId> <artifactId>selenium-java</artifactId> </dependency> |
Search
相关文章
热门文章
最新文章
文章分类
- ajax (10)
- algorithm-learn (3)
- Android (6)
- as (3)
- computer (85)
- Database (30)
- disucz (4)
- enterprise (1)
- erlang (2)
- flash (5)
- golang (3)
- html5 (18)
- ios (4)
- JAVA-and-J2EE (186)
- linux (143)
- mac (10)
- movie-music (11)
- pagemaker (36)
- php (50)
- spring-boot (2)
- Synology群晖 (2)
- Uncategorized (6)
- unity (1)
- webgame (15)
- wordpress (33)
- work-other (2)
- 低代码 (1)
- 体味生活 (40)
- 前端 (21)
- 大数据 (8)
- 游戏开发 (9)
- 爱上海 (19)
- 读书 (4)
- 软件 (3)