首页 > 其他分享 >Spring IOC

Spring IOC

时间:2022-12-06 15:15:25浏览次数:73  
标签:Spring void bean println out IOC public 属性

Spring IOC

介绍

介绍引用于 https://baijiahao.baidu.com/s?id=1712887849553755889&wfr=spider&for=pc

  • IOC全称是Inversion of Control,控制反转。它是一种设计思想,由容器将设计好的对象交给容器控制,而非对象内部直接new。

  • 传统的Java设计中,直接会在对象的内部通过new进行对象的创建,是程序主动创建以来对象;对IOC来说,有一个专门的容器专门管理这些对象的生命周期,控制对象的创建;所以在IOC中,是通过IOC容器控制对象,由IOC容器控制外部资源的获取。

  • 传统应用中是由我们自己在对象中主动控制去直接获取以来对象;反转则是通过容器来进行对象的依赖和创建,这里,对象只是被动的接收依赖对象,因此称为反转,而反转的则是依赖对象的获取被反转了。

  • IOC不是一种具体的技术,而是一种设计思想,IOC的目的是为了如何指导我们编写出更加松耦合,更加优雅的程序。传统的应用程序使我们在类的内部显式的创建依赖的对象。从而导致类于类之间耦合度过高。而使用了IOC的设计思想,将对象的创建,查找依赖,以及生命周期的控制权交给了IOC容器。对象之间耦合较松,更加灵活。

IOC 底层原理

xml 解析、工厂模式、反射

  1. xml配置文件,配置创建的对象(bean)

  2. 创建工厂类,将xml解析、通过反射创建对象

IOC(BeanFactory 接口)

  1. IOC 思想基于 IOC 容器完成,IOC 容器底层就是对象工厂

  2. Spring 提供 IOC 容器实现两种方式:(两个接口)
    (1)BeanFactory:IOC 容器基本实现,是 Spring 内部的使用接口,不提供开发人员进行使用。加载配置文件时候不会创建对象,在获取对象(使用)才去创建对象
    (2)ApplicationContext:BeanFactory 接口的子接口,提供更多更强大的功能,一般由开发人
    员进行使用。加载配置文件时候就会把在配置文件对象进行创建

  3. ApplicationContext 接口

    FileSystemXmlApplicationContext:在磁盘中去查找
    ClassPathXmlApplicationContext:在src目录下查找

  4. BeanFactory 接口,可以看到 ApplicationContext 是他的子接口

    ConfigurableApplicationContext:扩展接口

IOC 操作 Bean 管理

Bean 管理指的是两个操作
(1)Spring 创建对象
(2)Spirng 注入属性

Bean 管理操作有两种方式
(1)基于 xml 配置文件方式实现
(2)基于注解方式实现

基于 xml 方式

基于 xml 方式创建对象

<!--配置 User 对象创建-->
<bean id="user" class="com.zjh.spring.User"/>
  • 在 spring 配置文件中,使用 bean 标签,标签里面添加对应属性,就可以实现对象创建

  • 在 bean 标签有很多属性,介绍常用的属性

    • id 属性:唯一标识
    • class 属性:类全路径(包类路径)
  • 创建对象时候,默认也是执行无参数构造方法完成对象创建

基于 xml 方式注入属性

(1)DI:依赖注入,就是注入属性

第一种注入方式:使用 set 方法进行注入

(1)创建类,定义属性和对应的 set 方法

public class Book {

    private String bookName;
    
    private String bookAuthor;

    public void setBookName(String bookName) {
        this.bookName = bookName;
    }

    public void setBookAuthor(String bookAuthor) {
        this.bookAuthor = bookAuthor;
    }
    
    public void testBook() {
        System.out.println(bookName + ", 作者是:" + bookAuthor);
    }
}

(2)在 spring 配置文件配置对象创建,配置属性注入

<!-- set 方法注入属性 -->
<bean id="book" class="com.zjh.spring.Book">
    <!-- 使用 property 完成属性注入
    name:类里面属性名称
    value:向属性注入的值
    -->
    <property name="bookName" value="西游记"/>
    <property name="bookAuthor" value="吴承恩"/>
</bean>

(3)测试方法

@Test
public void testSet() {
    // 加载 spring 配置文件
    ApplicationContext context =
            new ClassPathXmlApplicationContext("bean.xml");

    // 获取配置创建的对象
    Book book = context.getBean("book", Book.class);
    System.out.println(book);
    book.testBook();
}

(4)结果

第二种注入方式:使用有参数构造进行注入

(1)创建类,定义属性,创建属性对应有参数构造方法

public class Order {
    
    private String name;

    private String address;

    /**
     * 有参构造函数
     * @param name     商品名称
     * @param address  地址
     */
    public Order(String name, String address) {
        this.name = name;
        this.address = address;
    }

    public void testOrder() {
        System.out.println("某某某在" + address + "购买了一台" + name);
    }
}

(2)在 spring 配置文件中进行配置

<!-- 有参数构造注入属性-->
<bean id="order" class="com.zjh.spring.Order">
    <!-- 使用 constructor-arg 完成属性注入
    name:类里面属性名称
    value:向属性注入的值
    -->
    <constructor-arg name="name" value="电脑"/>
    <constructor-arg name="address" value="合肥"/>
</bean>

(3)测试方法

@Test
public void testConstructor() {
    // 加载 spring 配置文件
    ApplicationContext context =
            new ClassPathXmlApplicationContext("bean.xml");

    // 获取配置创建的对象
    Order order = context.getBean("order", Order.class);
    System.out.println(order);
    order.testOrder();
}

(4)结果

p 名称空间注入(了解)

(1)使用 p 名称空间注入,可以简化基于 xml 配置方式。第一步:添加 p 名称空间在配置文件中

xmlns:p="http://www.springframework.org/schema/p"

(2)第二步:进行属性注入,在 bean 标签里面进行操作

<!-- 使用p名称空间 set 方法注入属性 -->
<bean id="pBook" class="com.zjh.spring.Book" p:bookName="西游记" p:bookAuthor="吴承恩"/>

测试方法,跟上方一样照猫画虎!!! 我就不写测试方法和结果了

xml 注入其他类型属性

字面量

(1)null 值

<!--null 值-->
<property name="address">
    <null/>
</property>

(2)属性值包含特殊符号

<!--属性值包含特殊符号
 1 把<>进行转义 &lt; &gt;
 2 把带特殊符号内容写到 CDATA
-->
<property name="address">
    <value><![CDATA[<<南京>>]]></value>
</property>

注入属性-外部 bean

(1)创建两个类 service 类和 dao 类,在 service 调用 dao 里面的方法

public interface UserDao {

    /**
     * 修改方法
     */
    void update();
}
public class UserDaoImpl implements UserDao{

    @Override
    public void update() {
        System.out.println("dao update......");
    }
}
public class UserService {

    private UserDao userDao;

    public void setUserDao(UserDao userDao){
        this.userDao = userDao;
    }

    public void add() {
        System.out.println("service add......");
        userDao.update();
    }
}

(3)在 spring 配置文件中进行配置

<!-- service 和 dao 对象创建-->
<bean id="userService" class="com.zjh.spring.service.UserService">
    <!--注入 userDao 对象
    name 属性:类里面属性名称
    ref 属性:创建 userDao 对象 bean 标签 id 值
    -->
    <property name="userDao" ref="userDaoImpl"/>
</bean>

<bean id="userDaoImpl" class="com.zjh.spring.dao.UserDaoImpl"/>

注入属性-内部 bean

(1)一对多关系:部门和员工。一个部门有多个员工,一个员工属于一个部门。部门是一,员工是多
(2)在实体类之间表示一对多关系,员工表示所属部门,使用对象类型属性进行表示

public class Dept {

    private String deptName;

    public String getDeptName() {
        return deptName;
    }

    public void setDeptName(String deptName) {
        this.deptName = deptName;
    }
}
public class Emp {

    private String name;

    private String gender;

    /**
     * 员工属于某一个部门,使用对象形式表示
     */
    private Dept dept;

    public void setName(String name) {
        this.name = name;
    }

    public void setGender(String gender) {
        this.gender = gender;
    }

    public void setDept(Dept dept) {
        this.dept = dept;
    }

    public void show() {
        System.out.println("我叫:" + name + ", 性别:" + gender + ", 属于:" + dept.getDeptName());
    }
}

(3)在 spring 配置文件中进行配置

<!--内部 bean-->
<bean id="emp" class="com.zjh.spring.bean.Emp">
    <!--设置两个普通属性-->
    <property name="name" value="zjh"/>
    <property name="gender" value="男"/>
    <!--设置对象类型属性-->
    <property name="dept">
        <bean class="com.zjh.spring.bean.Dept">
            <property name="deptName" value="技术部"/>
        </bean>
    </property>
</bean>

注入属性-级联赋值

(1)第一种写法

<!--级联赋值-->
<bean id="emp" class="com.zjh.spring.bean.Emp">
    <!--设置两个普通属性-->
    <property name="name" value="lucy"/>
    <property name="gender" value="女"/>
    <!--级联赋值-->
    <property name="dept" ref="dept"/>
</bean>
<bean id="dept" class="com.zjh.spring.bean.Dept">
    <property name="deptName" value="财务部"/>
</bean>

(2)第二种写法,需要给 dept 加上get方法,要不然获取不到属性

public Dept getDept() {
    return dept;
}
<!--级联赋值-->
<bean id="emp" class="com.zjh.spring.bean.Emp">
    <!--设置两个普通属性-->
    <property name="name" value="lucy"/>
    <property name="gender" value="女"/>
    <!--级联赋值-->
    <property name="dept" ref="dept"/>
    <property name="dept.deptName" value="技术部" />
</bean>
<bean id="dept" class="com.zjh.spring.bean.Dept" />

xml 注入集合属性

注入数组类型属性

注入 List 集合类型属性

注入 Map 集合类型属性

(1)创建类,定义数组、list、map、set 类型属性,生成对应 set 方法

public class Stu {

    /**
     * 数组类型属性
     */
    private String[] courses;
    /**
     * list 集合类型属性
     */
    private List<String> list;
    /**
     * map 集合类型属性
     */
    private Map<String,String> maps;
    /**
     * set 集合类型属性
     */
    private Set<String> sets;

    public void setSets(Set<String> sets) {
        this.sets = sets;
    }

    public void setCourses(String[] courses) {
        this.courses = courses;
    }

    public void setList(List<String> list) {
        this.list = list;
    }

    public void setMaps(Map<String, String> maps) {
        this.maps = maps;
    }

    public void show() {
        System.out.println("数组类型属性:" + Arrays.toString(courses));
        System.out.println("list集合类型属性:" + list.toString());
        System.out.println("map集合类型属性:" + maps.toString());
        System.out.println("set集合类型属性:" + sets.toString());
    }
}

(2)在 spring 配置文件进行配置

<!-- 集合类型属性注入-->
<bean id="stu" class="com.zjh.spring.collection.Stu">
    <!--数组类型属性注入-->
    <property name="courses">
        <array>
            <value>java 课程</value>
            <value>数据库课程</value>
        </array>
    </property>
    <!--list 类型属性注入-->
    <property name="list">
        <list>
            <value>张三</value>
            <value>小三</value>
        </list>
    </property>
    <!--map 类型属性注入-->
    <property name="maps">
        <map>
            <entry key="JAVA" value="java"/>
            <entry key="PHP" value="php"/>
        </map>
    </property>
    <!--set 类型属性注入-->
    <property name="sets">
        <set>
            <value>MySQL</value>
            <value>Redis</value>
        </set>
    </property>
</bean>

在集合里面设置对象类型值

public class Course {

    private String courseName;

    public String getCourseName() {
        return courseName;
    }
    public void setCourseName(String courseName) {
        this.courseName = courseName;
    }
}
/**
 * list 集合设置对象类型值
 */
private List<Course> courseList;

public void setCourseList(List<Course> courseList) {
    this.courseList = courseList;
}
<!--注入 list 集合类型,值是对象-->
<property name="courseList">
    <list>
        <ref bean="courseOne"/>
        <ref bean="courseTwo"/>
    </list>
</property>
<!--创建多个 course 对象-->
<bean id="courseOne" class="com.zjh.spring.collection.Course">
    <property name="courseName" value="Spring5 框架"/>
</bean>
<bean id="courseTwo" class="com.zjh.spring.collection.Course">
    <property name="courseName" value="MyBatis 框架"/>
</bean>

把集合注入部分提取出来

(1)在 spring 配置文件中引入名称空间 util

xmlns:util="http://www.springframework.org/schema/util"
http://www.springframework.org/schema/util
http://www.springframework.org/schema/util/spring-util.xsd

(2)创建 List属性

public class Book {

    private List<String> list;

    public void setList(List<String> list) {
        this.list = list;
    }

    public void show() {
        System.out.println("util:list注入的值:" + list.toString());
    }
}

(3)使用 util 标签完成 list 集合注入提取

<!-- 提取 list 集合类型属性注入-->
<util:list id="bookUtilList">
    <value>进击的巨人</value>
    <value>死神</value>
    <value>JoJo的奇妙冒险</value>
</util:list>

<!-- 提取 list 集合类型属性注入使用-->
<bean id="bookList" class="com.zjh.spring.collection.Book">
    <property name="list" ref="bookUtilList"/>
</bean>

FactoryBean

Spring 有两种类型 bean,一种普通 bean,另外一种工厂 bean(FactoryBean)

  • 普通 bean:在配置文件中定义 bean 类型就是返回类型

  • 工厂 bean:在配置文件定义 bean 类型可以和返回类型不一样

第一步 创建类,让这个类作为工厂 bean,实现接口 FactoryBean
第二步 实现接口里面的方法,在实现的方法中定义返回的 bean 类型

public class MyBean implements FactoryBean<Course> {

    @Override
    public Course getObject() throws Exception {
        Course course = new Course();
        course.setCourseName("java");
        return course;
    }

    @Override
    public Class<?> getObjectType() {
        return null;
    }

    @Override
    public boolean isSingleton() {
        return FactoryBean.super.isSingleton();
    }
}

第三步 注入bean

<bean id="myBean" class="com.zjh.spring.factorybean.MyBean"/>

第四步 测试方法

@Test
public void testFactoryBean() {
    // 加载 spring 配置文件
    ApplicationContext context =
            new ClassPathXmlApplicationContext("beanFactory.xml");

    // 获取配置创建的对象
    Course course = (Course) context.getBean("myBean");
    System.out.println(course.getCourseName());
}

bean 作用域

在 Spring 里面,设置创建 bean 实例是单实例还是多实例。在 Spring 里面,默认情况下,bean 是单实例对象,如下图所示:

如何设置单实例还是多实例

  1. 在 spring 配置文件 bean 标签里面有属性(scope)用于设置单实例还是多实例
  • scope 属性值
    • singleton:表示是单实例对象
    • prototype:表示是多实例对象
  1. singletonprototype 区别
    (1)singleton 单实例,prototype 多实例
    (2)设置 scope 值是 singleton 时候,加载 spring 配置文件时候就会创建单实例对象设置 scope 值是 prototype 时候,不是在加载 spring 配置文件时候创建对象,在调用 getBean 方法时候创建多实例对象

bean 生命周期

生命周期

(1)通过构造器创建 bean 实例(无参数构造)
(2)为 bean 的属性设置值和对其他 bean 引用(调用 set 方法)
(3)调用 bean 的初始化的方法(需要进行配置初始化的方法)
(4)bean 可以使用了(对象获取到了)
(5)当容器关闭时候,调用 bean 的销毁的方法(需要进行配置销毁的方法)

代码演示上述步骤

(1)创建 Orders 类,实现上述步骤方法

public class Orders {

    private String orderName;

    public Orders(){
        System.out.println("第一步 执行无参数构造创建 bean 实例");
    }

    public String getOrderName() {
        return orderName;
    }

    public void setOrderName(String orderName) {
        this.orderName = orderName;
        System.out.println("第二步 调用 set 方法设置属性值");
    }

    /**
     * 创建执行初始化的方法
     */
    public void initMethod() {
        System.out.println("第三步 执行初始化的方法");
    }

    /**
     * 创建执行的销毁的方法
     */
    public void destroyMethod() {
        System.out.println("第五步 执行销毁的方法");
    }
}

(2)配置 初始化方法和销毁方法

<!--配置 User 对象创建
    init-method 初始化加载方法 
    destroy-method 销毁加载方法
-->
<bean id="orders" class="com.zjh.spring.bean.Orders" init-method="initMethod" destroy-method="destroyMethod">
    <property name="orderName" value="手机"/>
</bean>

(3)测试方法

@Test
public void testSMZQ() {
    // 加载 spring 配置文件
    ClassPathXmlApplicationContext context =
            new ClassPathXmlApplicationContext("beanSNZQ.xml");

    // 获取配置创建的对象
    Orders orders = context.getBean("orders", Orders.class);
    System.out.println("第四步 获取创建 bean 实例对象值:" + orders.getOrderName());

    // 手动让 bean 实例销毁
    context.close();
}

(4)结果

bean 的前后置处理器,bean 生命周期有七步

(1)通过构造器创建 bean 实例(无参数构造)
(2)为 bean 的属性设置值和对其他 bean 引用(调用 set 方法)
(3)把 bean 实例传递 bean 后置处理器的方法 postProcessBeforeInitialization
(4)调用 bean 的初始化的方法(需要进行配置初始化的方法)
(5)把 bean 实例传递 bean 后置处理器的方法 postProcessAfterInitialization
(6)bean 可以使用了(对象获取到了)
(7)当容器关闭时候,调用 bean 的销毁的方法(需要进行配置销毁的方法)

代码演示 前后置处理器效果

(1)创建类,实现接口 BeanPostProcessor,创建后置处理器。重写postProcessBeforeInitialization、postProcessAfterInitialization方法

public class MyBeanPost implements BeanPostProcessor {

    @Override
    public Object postProcessBeforeInitialization(Object bean, String beanName) throws BeansException {
        System.out.println("在初始化之前执行的方法");
        return bean;
    }

    @Override
    public Object postProcessAfterInitialization(Object bean, String beanName) throws BeansException {
        System.out.println("在初始化之后执行的方法");
        return bean;
    }
}

(2)配置前后置处理器

<!-- 配置后置处理器-->
<bean id="myBeanPost" class="com.zjh.spring.bean.MyBeanPost" />

(3)测试方法跟上面一样
(4)结果

xml 自动装配

根据指定装配规则(属性名称或者属性类型),Spring 自动将匹配的属性值进行注入

根据属性名称装配

<!--实现自动装配
     bean 标签属性 autowire,配置自动装配
     autowire 属性常用两个值:
         byName 根据属性名称注入 ,注入值 bean 的 id 值和类属性名称一样
         byType 根据属性类型注入
-->
<bean id="autowireEmp" class="com.zjh.spring.autowire.AutowireEmp" autowire="byName" />

<bean id="autowireDept" class="com.zjh.spring.autowire.AutowireDept" />

根据属性类型装配

<bean id="autowireEmp" class="com.zjh.spring.autowire.AutowireEmp" autowire="byType" />

<bean id="autowireDept" class="com.zjh.spring.autowire.AutowireDept" />

外部属性文件

配置数据库信息

(1)配置德鲁伊连接池
(2)下载德鲁伊jar包并引入

<!--直接配置连接池-->
<bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource">
    <property name="driverClassName" value="com.mysql.jdbc.Driver"/>
    <property name="url" value="jdbc:mysql://localhost:3306/userDb"/>
    <property name="username" value="root"/>
    <property name="password" value="root"/>
</bean>

引入外部属性文件配置数据库连接池

(1)创建外部属性文件,properties 格式文件,写数据库信息

prop.driverClass=com.mysql.jdbc.Driver
prop.url=com.mysql.jdbc.Driver
prop.userName=root
prop.password=root

(2)先引入 context 名称空间,在把外部 properties 属性文件引入到 spring 配置文件中

xmlns:context="http://www.springframework.org/schema/context"
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context.xsd

<!--引入外部属性文件-->
<context:property-placeholder location="classpath:jdbc.properties"/>

<!--配置连接池-->
<bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource">
    <property name="driverClassName" value="${prop.driverClass}"/>
    <property name="url" value="${prop.url}"/>
    <property name="username" value="${prop.userName}"/>
    <property name="password" value="${prop.password}"/>
</bean>

基于注解方式

什么是注解

(1)注解是代码特殊标记,格式:@注解名称(属性名称=属性值, 属性名称=属性值..)
(2)使用注解,注解作用在类上面,方法上面,属性上面
(3)使用注解目的:简化 xml 配置

Spring 针对 Bean 管理中创建对象提供注解

(1)@Component:使用于组件上
(2)@Service:使用于业务逻辑层上
(3)@Controller:使用于控制层上
(4)@Repository:使用于持久层上

  • 上面四个注解功能是一样的,都可以用来创建 bean 实例

基于注解方式实现对象创建

(1)引入 jar 包

(2)开启组件扫描

<!--开启组件扫描
    如果扫描多个包有以下两种方法
        1 多个包使用逗号隔开
        2 扫描包上层目录
-->
<context:component-scan base-package="com.zjh.spring"/>

(3)创建类,在类上面添加创建对象注解

/**
 * @author zjh
 *
 * <bean id="userService" class=".."/> 同下方注解一个意思
 */
@Service(value = "userService")
public class UserService {

    public void add() {
        System.out.println("service add......");
    }
}

(4)测试方法

@Test
public void test() {
    ApplicationContext context = new ClassPathXmlApplicationContext("bean.xml");

    UserService userService = context.getBean("userService", UserService.class);
    System.out.println(userService);
    userService.add();
}

(5)结果

开启组件扫描细节配置

<!--示例 1
 use-default-filters="false" 表示现在不使用默认 filter,自己配置 filter
 context:include-filter 设置扫描哪些内容
-->
<context:component-scan base-package="com.zjh.spring" use-default-filters="false">
    <context:include-filter type="annotation"
                            expression="org.springframework.stereotype.Controller"/>
    </context:component-scan>

<!--示例 2
 下面配置扫描包所有内容
 context:exclude-filter: 设置哪些内容不进行扫描
-->
<context:component-scan base-package="com.zjh.spring">
    <context:exclude-filter type="annotation"
                            expression="org.springframework.stereotype.Controller"/>
    </context:component-scan>

基于注解方式实现属性注入

(1)@Autowired:根据属性类型进行自动装配
第一步 把 service 和 dao 对象创建,在 service 和 dao 类添加创建对象注解
第二步 在 service 注入 dao 对象,在 service 类添加 dao 类型属性,在属性上面使用注解

@Service(value = "userService")
public class UserService {

    /**
     * 注入 userDao
     */
    @Autowired
    private UserDao userDao;

    public void add() {
        System.out.println("service add......");
        userDao.update();
    }
}

(2)@Qualifier:根据名称进行注入
@Qualifier 注解的使用,和上面@Autowired 一起使用

@Service(value = "userService")
public class UserService {

    /**
     * 注入 userDao
     *
     * Autowired注解根据类型进行注入,如果有两个同类型的bean就会出错,就可以使用
     * 到Qualifier注解根据名称注入。
     */
    @Autowired
    @Qualifier(value = "userDaoImpl")
    private UserDao userDao;

    public void add() {
        System.out.println("service add......");
        userDao.update();
    }
}

(3)@Resource:默认是按照名称来装配注入的,只有当找不到与名称匹配的bean才会按照类型来注入

@Service(value = "userService")
public class UserService {

    @Resource
    private UserDao userDao;

    public void add() {
        System.out.println("service add......");
        userDao.update();
    }
}

(4)@Value:注入普通类型属性

/**
 * 会将 zjh 注入到 name 中
 */
@Value(value = "zjh")
private String name;

完全注解开发

(1)创建配置类,替代 xml 配置文件

/**
 * @author zjh
 */
@Configuration
@ComponentScan(basePackages = {"com.zjh.spring"})
public class SpringConfig {

}

(2)编写测试类

@Test
public void testAllAnnotations() {
    // AnnotationConfigApplicationContext 加载配置类
    ApplicationContext context = new AnnotationConfigApplicationContext(SpringConfig.class);

    UserService userService = context.getBean("userService", UserService.class);
    System.out.println(userService);
    userService.add();
}

标签:Spring,void,bean,println,out,IOC,public,属性
From: https://www.cnblogs.com/zjh0420/p/16951863.html

相关文章

  • Spring 概述-入门案列
    Spring概述-入门案列介绍Spring是轻量级的开源的JavaEE框架Spring可以解决企业应用开发的复杂性Spring有两个核心部分:IOC和AOP(1)IOC:控制反转,把创建对象......
  • Springboot优雅进行字段检验
    Springboot优雅进行字段检验1、ControllerVSService推荐与业务无关的放在controller层中进行校验,而与业务相关的放在service层中校验。2、常用校验工具类使用Hiberna......
  • springboot2 搭建日志收集系统存入mongodb + redis+mq+线程池+xxljobs
    我们看到了高效批量插入mongodb速度还不错,那么我们的系统日志收集怎么做呢。当然当前文件日志收集效果也不错,比如前面博文写的elkf搭建日志收集系统。但我们系统中总是有......
  • springboot2 mongodb 高效批量入库--环境搭建
    当今使用微服务越来越多,每个服务都需要记录日志,那么记录到mysql中已完全不合适了。那么就记录到mongo中吧。想要速度快,那么一定要使用批量保存,做过尝试入库10万数据,逐条插......
  • Spring用XML方式使用事务
    项目开始前需要新建数据库(数据库使用mysql8.0以上的版本)#创建数据库CREATEdatabaseuserdb;#创建数据表CREATETABLEuserdb.t_account(idintNOTNULL,usernamev......
  • SpringBoot整合Netty+WebSocket
    SpringBoot整合Netty+WebSocket构建环境pom.xml<?xmlversion="1.0"encoding="UTF-8"?><projectxmlns="http://maven.apache.org/POM/4.0.0"xmlns:xsi="http://www.w......
  • SpringBoot 接口并发限制(Semaphore)
    可以使用JMeter辅助测试https://blog.csdn.net/weixin_45014379/article/details/124190381@RestController@RequestMapping({"/Test"})publicclasstest{L......
  • 对graalvm、springboot3.0一些新特性的探究
    环境:系统:IntelcoreMacVentura13.0.1工具: Idea:2022.2.3 gradle:7.4(idea自带的)  openjdk:version"17.0.5"2022-10-18 graalvm: CE22.3.0 ......
  • 【重温SSM框架系列】10 - Spring AOP开发的两种方式(基于XML、基于注解)
    AOP开发​​概述​​​​基于XML的AOP开发​​​​1.导入AOP依赖包​​​​2.创建目标类和接口​​​​3.创建切面类(增强方法类)​​​​4.将目标类和切面类交给Spri......
  • centos 7.6 部署spring自动化运维环境一nginx安装
    首先安装所需的环境一.安装PCREpcre-devel#####yuminstall-ypcrepcre-devel二.安装gcc#####yum-yinstallgccgcc-c++kernel-devel三.安装zlib#####yumins......