事件存储连接已关闭
Event Store connection was closed
使用以下 docker-compose 文件启动我的 .Net Core 3.1 控制台应用程序和一个事件存储容器。
version: "3.4"
services:
eventstore:
image: eventstore/eventstore
networks:
- eventnet
ports:
- "2113:2113"
- "1113:1113"
consoleapp4:
image: ${DOCKER_REGISTRY-}consoleapp4
build:
context: .
dockerfile: ConsoleApp4/Dockerfile
depends_on:
- eventstore
networks:
eventnet:
driver: bridge
在 building/running docker-compose 文件之后,EventStore UI 可在 http://localhost:2113 上访问;这样就可以了。
我的控制台很简单,看起来像这样,但是连接有问题。我收到类型为
的未处理异常
'EventStore.ClientAPI.Exceptions.ConnectionClosedException' occurred in System.Private.CoreLib.dll: 'Connection 'MyConName' was closed.':
using System;
using EventStore.ClientAPI;
using Newtonsoft.Json;
namespace ConsoleApp4
{
class Program
{
static void Main(string[] args)
{
var connectionSettings = ConnectionSettings.Create();
connectionSettings.UseConsoleLogger().UseDebugLogger().EnableVerboseLogging().Build();
var connection = EventStoreConnection.Create("ConnectTo=tcp://admin:changeit@localhost:1113", connectionSettings, "MyConName");
connection.Connected += (a, b) =>
{
var x = 3; // Never comes here
};
connection.ErrorOccurred += (a, b) =>
{
var x = 5; // Never comes here
};
connection.ConnectAsync().Wait();
var model = new MyModel();
var item = new EventData(model.Id, model.GetTypeString(), true, model.GetByteArray(), new byte[] { });
// Throws exception 'EventStore.ClientAPI.Exceptions.ConnectionClosedException'
var result = connection.AppendToStreamAsync("mystream", 0, item).GetAwaiter().GetResult();
}
}
class MyModel
{
public Guid Id { get; } = Guid.NewGuid();
public string GetTypeString() => this.GetType().FullName.ToLower();
public byte[] GetByteArray() => System.Text.Encoding.UTF8.GetBytes(JsonConvert.SerializeObject(this));
}
}
我完全没有知道该做什么了,所以任何指示都将不胜感激,它一定很简单吧..?
我试过另一台机器,完全重新开始,试过 IP 地址,另一种设置连接字符串的方法,Powershell 告诉:
C:\WINDOWS\system32> Test-NetConnection -ComputerName localhost -Port 1113
ComputerName : localhost
RemoteAddress : ::1
RemotePort : 1113
InterfaceAlias : Loopback Pseudo-Interface 1
SourceAddress : ::1
TcpTestSucceeded : True
编辑
将我的 docker-compose 文件更改为:
version: '3.4'
services:
myeventstore:
image: eventstore/eventstore
ports:
- "2113:2113"
- "1113:1113"
console:
image: ${DOCKER_REGISTRY-}console
build:
context: .
dockerfile: Console/Dockerfile
depends_on:
- myeventstore
或
version: '3.4'
services:
myeventstore:
image: eventstore/eventstore
ports:
- "2113:2113"
- "1113:1113"
networks:
- eventsnet
console:
image: ${DOCKER_REGISTRY-}console
build:
context: .
dockerfile: Console/Dockerfile
depends_on:
- myeventstore
networks:
- eventsnet
networks:
eventsnet:
driver: bridge
和连接字符串到:myeventstore
仍然没有成功...
尽管事实上我无法让这个东西像最初要求的那样工作,但我确实设法通过 SSL 使它工作;使用自签名证书。
创建自签名证书的 Dockerfile,用于开发环境:
FROM eventstore/eventstore
RUN apt-get update -y \
&& apt-get install -y openssl \
&& openssl req -x509 -sha256 -nodes -days 3650 -subj "/CN=eventstore.org" -newkey rsa:2048 -keyout eventstore.pem -out eventstore.csr \
&& openssl pkcs12 -export -inkey eventstore.pem -in eventstore.csr -out eventstore.p12 -passout pass: \
&& openssl pkcs12 -export -inkey eventstore.pem -in eventstore.csr -out eventstore.pfx -passout pass: \
&& mkdir -p /usr/local/share/ca-certificates \
&& cp eventstore.csr /usr/local/share/ca-certificates/eventstore.crt \
&& update-ca-certificates \
&& apt-get autoremove \
&& apt-get clean \
&& rm -rf /var/lib/apt/lists/* /tmp/* /var/tmp/*
我的 docker-compose 文件如下所示:
version: '3.4'
services:
myeventstore:
image: eventstore/eventstore:with-cert-local
build:
context: .
dockerfile: .docker/EventStore/Dockerfile
ports:
- "2113:2113"
- "1113:1113"
- "1115:1115"
environment:
- EVENTSTORE_CERTIFICATE_FILE=eventstore.p12
- EVENTSTORE_EXT_SECURE_TCP_PORT=1115
console:
image: ${DOCKER_REGISTRY-}console
build:
context: .
dockerfile: Console/Dockerfile
depends_on:
- myeventstore
using System;
using System.Text;
using System.Threading.Tasks;
using EventStore.ClientAPI;
using Newtonsoft.Json;
namespace Console
{
internal static class Program
{
private static async Task Main()
{
var connectionSettings = ConnectionSettings.Create();
connectionSettings.EnableVerboseLogging()
.UseDebugLogger()
.UseConsoleLogger()
.SetHeartbeatTimeout(TimeSpan.FromSeconds(60))
.SetHeartbeatInterval(TimeSpan.FromSeconds(30));
var connection = EventStoreConnection.Create(
"ConnectTo=tcp://myeventstore:1115;DefaultUserCredentials=admin:changeit;UseSslConnection=true;TargetHost=eventstore.org;ValidateServer=false",
connectionSettings, "MyConName");
await connection.ConnectAsync();
var model = new MyModel();
var item = new EventData(model.Id, model.GetTypeString(), true, model.GetByteArray(), new byte[] { });
var result = await connection.AppendToStreamAsync("mystream", ExpectedVersion.Any, item);
}
}
public class MyModel : MyBaseEvent, IEventId
{
/// <inheritdoc />
public Guid Id { get; } = Guid.NewGuid();
}
public abstract class MyBaseEvent
{
public string GetTypeString() => GetType().ToString().ToLower();
public byte[] GetByteArray() => Encoding.UTF8.GetBytes(JsonConvert.SerializeObject(this));
}
public interface IEventId
{
Guid Id { get; }
}
}
使用以下 docker-compose 文件启动我的 .Net Core 3.1 控制台应用程序和一个事件存储容器。
version: "3.4"
services:
eventstore:
image: eventstore/eventstore
networks:
- eventnet
ports:
- "2113:2113"
- "1113:1113"
consoleapp4:
image: ${DOCKER_REGISTRY-}consoleapp4
build:
context: .
dockerfile: ConsoleApp4/Dockerfile
depends_on:
- eventstore
networks:
eventnet:
driver: bridge
在 building/running docker-compose 文件之后,EventStore UI 可在 http://localhost:2113 上访问;这样就可以了。
我的控制台很简单,看起来像这样,但是连接有问题。我收到类型为
的未处理异常'EventStore.ClientAPI.Exceptions.ConnectionClosedException' occurred in System.Private.CoreLib.dll: 'Connection 'MyConName' was closed.':
using System;
using EventStore.ClientAPI;
using Newtonsoft.Json;
namespace ConsoleApp4
{
class Program
{
static void Main(string[] args)
{
var connectionSettings = ConnectionSettings.Create();
connectionSettings.UseConsoleLogger().UseDebugLogger().EnableVerboseLogging().Build();
var connection = EventStoreConnection.Create("ConnectTo=tcp://admin:changeit@localhost:1113", connectionSettings, "MyConName");
connection.Connected += (a, b) =>
{
var x = 3; // Never comes here
};
connection.ErrorOccurred += (a, b) =>
{
var x = 5; // Never comes here
};
connection.ConnectAsync().Wait();
var model = new MyModel();
var item = new EventData(model.Id, model.GetTypeString(), true, model.GetByteArray(), new byte[] { });
// Throws exception 'EventStore.ClientAPI.Exceptions.ConnectionClosedException'
var result = connection.AppendToStreamAsync("mystream", 0, item).GetAwaiter().GetResult();
}
}
class MyModel
{
public Guid Id { get; } = Guid.NewGuid();
public string GetTypeString() => this.GetType().FullName.ToLower();
public byte[] GetByteArray() => System.Text.Encoding.UTF8.GetBytes(JsonConvert.SerializeObject(this));
}
}
我完全没有知道该做什么了,所以任何指示都将不胜感激,它一定很简单吧..?
我试过另一台机器,完全重新开始,试过 IP 地址,另一种设置连接字符串的方法,Powershell 告诉:
C:\WINDOWS\system32> Test-NetConnection -ComputerName localhost -Port 1113
ComputerName : localhost
RemoteAddress : ::1
RemotePort : 1113
InterfaceAlias : Loopback Pseudo-Interface 1
SourceAddress : ::1
TcpTestSucceeded : True
编辑
将我的 docker-compose 文件更改为:
version: '3.4'
services:
myeventstore:
image: eventstore/eventstore
ports:
- "2113:2113"
- "1113:1113"
console:
image: ${DOCKER_REGISTRY-}console
build:
context: .
dockerfile: Console/Dockerfile
depends_on:
- myeventstore
或
version: '3.4'
services:
myeventstore:
image: eventstore/eventstore
ports:
- "2113:2113"
- "1113:1113"
networks:
- eventsnet
console:
image: ${DOCKER_REGISTRY-}console
build:
context: .
dockerfile: Console/Dockerfile
depends_on:
- myeventstore
networks:
- eventsnet
networks:
eventsnet:
driver: bridge
和连接字符串到:myeventstore
仍然没有成功...
尽管事实上我无法让这个东西像最初要求的那样工作,但我确实设法通过 SSL 使它工作;使用自签名证书。
创建自签名证书的 Dockerfile,用于开发环境:
FROM eventstore/eventstore
RUN apt-get update -y \
&& apt-get install -y openssl \
&& openssl req -x509 -sha256 -nodes -days 3650 -subj "/CN=eventstore.org" -newkey rsa:2048 -keyout eventstore.pem -out eventstore.csr \
&& openssl pkcs12 -export -inkey eventstore.pem -in eventstore.csr -out eventstore.p12 -passout pass: \
&& openssl pkcs12 -export -inkey eventstore.pem -in eventstore.csr -out eventstore.pfx -passout pass: \
&& mkdir -p /usr/local/share/ca-certificates \
&& cp eventstore.csr /usr/local/share/ca-certificates/eventstore.crt \
&& update-ca-certificates \
&& apt-get autoremove \
&& apt-get clean \
&& rm -rf /var/lib/apt/lists/* /tmp/* /var/tmp/*
我的 docker-compose 文件如下所示:
version: '3.4'
services:
myeventstore:
image: eventstore/eventstore:with-cert-local
build:
context: .
dockerfile: .docker/EventStore/Dockerfile
ports:
- "2113:2113"
- "1113:1113"
- "1115:1115"
environment:
- EVENTSTORE_CERTIFICATE_FILE=eventstore.p12
- EVENTSTORE_EXT_SECURE_TCP_PORT=1115
console:
image: ${DOCKER_REGISTRY-}console
build:
context: .
dockerfile: Console/Dockerfile
depends_on:
- myeventstore
using System;
using System.Text;
using System.Threading.Tasks;
using EventStore.ClientAPI;
using Newtonsoft.Json;
namespace Console
{
internal static class Program
{
private static async Task Main()
{
var connectionSettings = ConnectionSettings.Create();
connectionSettings.EnableVerboseLogging()
.UseDebugLogger()
.UseConsoleLogger()
.SetHeartbeatTimeout(TimeSpan.FromSeconds(60))
.SetHeartbeatInterval(TimeSpan.FromSeconds(30));
var connection = EventStoreConnection.Create(
"ConnectTo=tcp://myeventstore:1115;DefaultUserCredentials=admin:changeit;UseSslConnection=true;TargetHost=eventstore.org;ValidateServer=false",
connectionSettings, "MyConName");
await connection.ConnectAsync();
var model = new MyModel();
var item = new EventData(model.Id, model.GetTypeString(), true, model.GetByteArray(), new byte[] { });
var result = await connection.AppendToStreamAsync("mystream", ExpectedVersion.Any, item);
}
}
public class MyModel : MyBaseEvent, IEventId
{
/// <inheritdoc />
public Guid Id { get; } = Guid.NewGuid();
}
public abstract class MyBaseEvent
{
public string GetTypeString() => GetType().ToString().ToLower();
public byte[] GetByteArray() => Encoding.UTF8.GetBytes(JsonConvert.SerializeObject(this));
}
public interface IEventId
{
Guid Id { get; }
}
}