发布一个k8s部署视频:https://edu.csdn.net/course/detail/26967
课程内容:各种k8s部署方式。包括minikube部署,kubeadm部署,kubeasz部署,rancher部署,k3s部署。包括开发测试环境部署k8s,和生产环境部署k8s。
腾讯课堂连接地址https://ke.qq.com/course/478827?taid=4373109931462251&tuin=ba64518
第二个视频发布 https://edu.csdn.net/course/detail/27109
腾讯课堂连接地址https://ke.qq.com/course/484107?tuin=ba64518
介绍主要的k8s资源的使用配置和命令。包括configmap,pod,service,replicaset,namespace,deployment,daemonset,ingress,pv,pvc,sc,role,rolebinding,clusterrole,clusterrolebinding,secret,serviceaccount,statefulset,job,cronjob,podDisruptionbudget,podSecurityPolicy,networkPolicy,resourceQuota,limitrange,endpoint,event,conponentstatus,node,apiservice,controllerRevision等。
第三个视频发布:https://edu.csdn.net/course/detail/27574
详细介绍helm命令,学习helm chart语法,编写helm chart。深入分析各项目源码,学习编写helm插件
————————————————------------------------------------------------------------------------------------------------------------------
public class ThreadPool {
private AtomicInteger maxSize;
private BlockingQueue<Runnable> taskQueue;
private List<TaskThread> threads=null;
private static ThreadPool instance =null;
private static Lock lock=new ReentrantLock();
private ThreadPool(int maxSize){
this.maxSize=new AtomicInteger(maxSize);
threads=new ArrayList<TaskThread>();
this.taskQueue=new LinkedBlockingDeque<Runnable>();
initThread();
}
private void initThread(){
for(int i=0;i<this.maxSize.get();i++){
TaskThread thread=new TaskThread();
threads.add(thread);
thread.start();
}
}
public static ThreadPool getInstance(int maxSize){
lock.lock();
try{
if(instance==null){
instance =new ThreadPool(maxSize);
}
return instance;
}finally{
lock.unlock();
}
}
public boolean submitJob(Runnable runable){
taskQueue.add(runable);
return true;
}
private class TaskThread extends Thread{
@Override
public void run() {
while(true){
try {
Runnable run=taskQueue.take();
run.run();
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
}
public static void main(String[] args) {
ThreadPool pool=ThreadPool.getInstance(10);
for(int i=0;i<100;i++){
pool.submitJob(new Thread() {
public void run() {
System.out.println(this.currentThread().getName());
try {
Thread.sleep(1000);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
});
}
}
}