Problèmes de développement généralement rencontrés - mise à jour continue

Question de développement 1: tuyau cassé

Description du problème:

Caused by: java.io.IOException: Broken pipe
	at sun.nio.ch.FileDispatcherImpl.write0(Native Method)
	at sun.nio.ch.SocketDispatcher.write(SocketDispatcher.java:47)
	at sun.nio.ch.IOUtil.writeFromNativeBuffer(IOUtil.java:93)
	at sun.nio.ch.IOUtil.write(IOUtil.java:65)
	at sun.nio.ch.SocketChannelImpl.write(SocketChannelImpl.java:471)
	at org.apache.tomcat.util.net.NioChannel.write(NioChannel.java:134)
	at org.apache.tomcat.util.net.NioBlockingSelector.write(NioBlockingSelector.java:101)
	at org.apache.tomcat.util.net.NioSelectorPool.write(NioSelectorPool.java:157)
	at org.apache.tomcat.util.net.NioEndpoint$NioSocketWrapper.doWrite(NioEndpoint.java:1225)
	at org.apache.tomcat.util.net.SocketWrapperBase.doWrite(SocketWrapperBase.java:743)
	at org.apache.tomcat.util.net.SocketWrapperBase.flushBlocking(SocketWrapperBase.java:696)
	at org.apache.tomcat.util.net.SocketWrapperBase.flush(SocketWrapperBase.java:686)
	at org.apache.coyote.http11.Http11OutputBuffer$SocketOutputBuffer.flush(Http11OutputBuffer.java:553)
	at org.apache.coyote.http11.filters.ChunkedOutputFilter.flush(ChunkedOutputFilter.java:157)
	at org.apache.coyote.http11.Http11OutputBuffer.flush(Http11OutputBuffer.java:216)
	at org.apache.coyote.http11.Http11Processor.flush(Http11Processor.java:1149)
	at org.apache.coyote.AbstractProcessor.action(AbstractProcessor.java:394)
	at org.apache.coyote.Response.action(Response.java:209)
	at org.apache.catalina.connector.OutputBuffer.doFlush(OutputBuffer.java:294)
Caused by: java.io.IOException: Connection reset by peer
	at sun.nio.ch.FileDispatcherImpl.write0(Native Method)
	at sun.nio.ch.SocketDispatcher.write(SocketDispatcher.java:47)
	at sun.nio.ch.IOUtil.writeFromNativeBuffer(IOUtil.java:93)
	at sun.nio.ch.IOUtil.write(IOUtil.java:65)
	at sun.nio.ch.SocketChannelImpl.write(SocketChannelImpl.java:471)
	at org.apache.tomcat.util.net.NioChannel.write(NioChannel.java:134)
	at org.apache.tomcat.util.net.NioBlockingSelector.write(NioBlockingSelector.java:101)
	at org.apache.tomcat.util.net.NioSelectorPool.write(NioSelectorPool.java:157)
	at org.apache.tomcat.util.net.NioEndpoint$NioSocketWrapper.doWrite(NioEndpoint.java:1225)
	at org.apache.tomcat.util.net.SocketWrapperBase.doWrite(SocketWrapperBase.java:743)
	at org.apache.tomcat.util.net.SocketWrapperBase.flushBlocking(SocketWrapperBase.java:696)
	at org.apache.tomcat.util.net.SocketWrapperBase.flush(SocketWrapperBase.java:686)
	at org.apache.coyote.http11.Http11OutputBuffer$SocketOutputBuffer.flush(Http11OutputBuffer.java:553)
	at org.apache.coyote.http11.filters.ChunkedOutputFilter.flush(ChunkedOutputFilter.java:157)
	at org.apache.coyote.http11.Http11OutputBuffer.flush(Http11OutputBuffer.java:216)
	at org.apache.coyote.http11.Http11Processor.flush(Http11Processor.java:1149)

causes du problème:

Cette exception est que le client lit le délai d'expiration et ferme la connexion. À ce moment, lorsque le serveur écrit des données sur la connexion déconnectée du client, une exception de canal interrompu se produit! La situation dans laquelle le problème se produit est l'opération de liste par lots de 100 produits et la connexion frontale a été déconnectée avant que l'interface principale ait fini de répondre.

Solution:

J'ai utilisé la méthode d'ouverture du multi-thread pour le traitement. Comme le délai de réponse a expiré, ouvrez quelques threads supplémentaires pour le traitement. Cela dépend de la situation. N'abusez pas du thread! ! !

Problème de développement deux

Description du problème:

causes du problème:

Solution:

En tant qu'ingénieur back-end, vous devez avoir un résumé cumulé de certaines anomalies et erreurs dans votre travail quotidien. Premièrement, après avoir résumé, vous ne serez pas perdu lorsque vous rencontrerez le même problème la prochaine fois, en particulier lorsque vous vous connecterez. , autres collègues Lorsque vous attendez que vous résolviez le problème, ce n'est pas très bon pour vous de gazouiller. Deuxièmement, on vous posera souvent des questions similaires pendant l'entretien. En tant qu'ingénieur expérimenté en recrutement social, vous ne pouvez pas embaucher d'écoles L'entretien comme votre propre standard, vous devez avoir votre propre accumulation d'expérience, et être prêt à affronter des situations incertaines à tout moment!

Je suppose que tu aimes

Origine blog.csdn.net/qq_37896194/article/details/115351778
conseillé
Classement