ThreadLocal的使用场景:Web容器、Spring容器、日志打印

一、对于HTTP事务的理解

一次HTTP请求,就是一个事务。事务者,必须完整的执行其中的所有步骤,不能中断。

二、HTTP事务的隔离

每次HTTP请求对应一个HTTP事务,而每个请求都对应一个线程,线程之间相互隔离,没有共享数据,这就是ThreadLocal一个典型的应用场景。

三、ThreadLocal在Web容器中的使用场景【针对HTTP事务】

ThreadLocal充当Web容器中存储Session的载体。当请求到来时,将当前Session信息存储在ThreadLocal中,在请求处理过程中可以随时使用Session信息,每个请求之间的Session信息互不影响。当请求处理完成后通过remove方法将当前Session信息清除即可。

四、ThreadLocal在Spring容器中的使用场景【针对JDBC事务】

Spring框架在事务开始时会给当前线程绑定一个Jdbc Connection,在整个事务过程都是使用该线程绑定的Connection来执行数据库操作,实现了事务的隔离性。

五、日志打印

同一线程的日志一起打印,或者说一次事务的日志一起打印,因为一般默认一次事务都是由同一个线程执行的,将事务的日志保存在线程局部变量当中,当事务执行完成的时候统一打印。

public class ErrorContext

{

 

    private static final String LINE_SEPARATOR = System.getProperty"line.separator", "
");

    private static final ThreadLocal<ErrorContext> LOCAL = new ThreadLocal<ErrorContext>);

 

    private String message;

 

    private ErrorContext)

    {

    }

 

    public static ErrorContext instance)

    {

        ErrorContext context = LOCAL.get);

        if context == null)

        {

            context = new ErrorContext);

            LOCAL.setcontext);

        }

        return context;

    }

 

    public ErrorContext messageString message)

    {

        this.message = message;

        return this;

    }

 

    public ErrorContext reset)

    {

 

        message = null;

        LOCAL.remove);

        return this;

    }

 

    @Override

    public String toString)

    {

        StringBuilder description = new StringBuilder);

 

        if this.message != null)

        {

            description.append"### ");

            description.appendthis.message);

            description.appendLINE_SEPARATOR);

        }

 

        return description.toString);

    }

 

    public static void mainString[] args)

    {

 

        Runnable task1 = ) -> {

 

            ErrorContext cxt = ErrorContext.instance);

            cxt.message"info");

 

            System.out.printlncxt);

            cxt.reset);

        };

 

        Runnable task2 = ) -> {

            ErrorContext cxt = ErrorContext.instance);

            cxt.message"error");

            System.out.printlncxt);

            cxt.reset);

        };

 

        new Threadtask1).start);

 

        new Threadtask2).start);

 

    }

}

六、参考内容

SpringMVC 中文官网:http://www.springmvc.cn/

Published by

风君子

独自遨游何稽首 揭天掀地慰生平