Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
The receive window size should be adjusted according to the max receiver buffer. Fix the following abort. Without reducing the receive window, the sender has no back pressure, if the application does not read the data, the _rcv.data grows unbounded, when the application read again, all the packet in _rcv.data will be merged into a single packet with tons of fragments and cause the assert. In seastar::net::tcp<seastar::net::ipv4_traits>::tcb::read(): for (auto&& q : _rcv.data) { p.append(std::move(q)); } server: /home/asias/src/cloudius-systems/scylla/seastar/net/packet.hh:144: static void* seastar::net::packet::impl::operator new(size_t, size_t): Assertion `nr_frags == uint16_t(nr_frags)' failed. Aborting on shard 0. Backtrace: 0x000000000041fafa 0x000000000041fbcc 0x000000000041fc83 /lib64/libpthread.so.0+0x000000000001241f /lib64/libc.so.6+0x00000000000369fa /lib64/libc.so.6+0x00000000000387ff /lib64/libc.so.6+0x000000000002f0d9 /lib64/libc.so.6+0x000000000002f151 0x00000000004b89dd 0x00000000005ab01e 0x00000000005cbc6a 0x00000000005dbfc1 0x00000000005db9b8 0x0000000000570986 0x0000000000570be5 0x000000000069859a 0x00000000006a16e5 0x000000000041d136 0x000000000041d422 0x000000000046b527 0x00000000004fba62 0x0000000000418e77 /lib64/libc.so.6+0x0000000000020889 0x0000000000419039 $ addr2line -Cfpi -e ./server 0x000000000041fafa 0x000000000041fbcc 0x000000000041fc83 /lib64/libpthread.so.0+0x000000000001241f /lib64/libc.so.6+0x00000000000369fa /lib64/libc.so.6+0x00000000000387ff /lib64/libc.so.6+0x000000000002f0d9 /lib64/libc.so.6+0x000000000002f151 0x00000000004b89dd 0x00000000005ab01e 0x00000000005cbc6a 0x00000000005dbfc1 0x00000000005db9b8 0x0000000000570986 0x0000000000570be5 0x000000000069859a 0x00000000006a16e5 0x000000000041d136 0x000000000041d422 0x000000000046b527 0x00000000004fba62 0x0000000000418e77 /lib64/libc.so.6+0x0000000000020889 0x0000000000419039 seastar::backtrace_buffer::append_backtrace() at /home/asias/src/cloudius-systems/scylla/seastar/core/reactor.cc:378 (inlined by) print_with_backtrace at /home/asias/src/cloudius-systems/scylla/seastar/core/reactor.cc:399 seastar::print_with_backtrace(char const*) at /home/asias/src/cloudius-systems/scylla/seastar/core/reactor.cc:406 sigabrt_action at /home/asias/src/cloudius-systems/scylla/seastar/core/reactor.cc:3914 (inlined by) operator() at /home/asias/src/cloudius-systems/scylla/seastar/core/reactor.cc:3896 (inlined by) _FUN at /home/asias/src/cloudius-systems/scylla/seastar/core/reactor.cc:3892 ?? ??:0 ?? ??:0 ?? ??:0 ?? ??:0 ?? ??:0 seastar::net::packet::impl::operator new(unsigned long, unsigned long) at /home/asias/src/cloudius-systems/scylla/seastar/net/packet.hh:144 (inlined by) seastar::net::packet::impl::allocate(unsigned long) at /home/asias/src/cloudius-systems/scylla/seastar/net/packet.hh:117 (inlined by) seastar::net::packet::impl::copy(seastar::net::packet::impl*, unsigned long) at /home/asias/src/cloudius-systems/scylla/seastar/net/packet.hh:121 (inlined by) seastar::net::packet::impl::allocate_if_needed(std::unique_ptr<seastar::net::packet::impl, std::default_delete<seastar::net::packet::impl> >, unsigned long) at /home/asias/src/cloudius-systems/scylla/seastar/net/packet.hh:141 seastar::net::packet::append(seastar::net::packet&&) at /home/asias/src/cloudius-systems/scylla/seastar/net/packet.hh:490 seastar::net::tcp<seastar::net::ipv4_traits>::tcb::read() at /home/asias/src/cloudius-systems/scylla/seastar/net/tcp.hh:1760 (inlined by) seastar::net::tcp<seastar::net::ipv4_traits>::connection::read() at /home/asias/src/cloudius-systems/scylla/seastar/net/tcp.hh:682 (inlined by) seastar::net::native_connected_socket_impl<seastar::net::tcp<seastar::net::ipv4_traits> >::native_data_source_impl::get()::{lambda()#2}::operator()() const at /home/asias/src/cloudius-systems/scylla/seastar/net/native-stack-impl.hh:145 (inlined by) seastar::apply_helper<seastar::net::native_connected_socket_impl<seastar::net::tcp<seastar::net::ipv4_traits> >::native_data_source_impl::get()::{lambda()#2}, std::tuple<>&&, std::integer_sequence<unsigned long> >::apply({lambda()#2}&&, std::tuple<>) at /home/asias/src/cloudius-systems/scylla/seastar/core/apply.hh:36 (inlined by) auto seastar::apply<seastar::net::native_connected_socket_impl<seastar::net::tcp<seastar::net::ipv4_traits> >::native_data_source_impl::get()::{lambda()#2}>(seastar::net::native_connected_socket_impl<seastar::net::tcp<seastar::net::ipv4_traits> >::native_data_source_impl::get()::{lambda()#2}&&, std::tuple<>&&) at /home/asias/src/cloudius-systems/scylla/seastar/core/apply.hh:44 (inlined by) seastar::future<seastar::temporary_buffer<char> > seastar::futurize<seastar::future<seastar::temporary_buffer<char> > >::apply<seastar::net::native_connected_socket_impl<seastar::net::tcp<seastar::net::ipv4_traits> >::native_data_source_impl::get()::{lambda()#2}>(seastar::net::native_connected_socket_impl<seastar::net::tcp<seastar::net::ipv4_traits> >::native_data_source_impl::get()::{lambda()#2}&&, std::tuple<>&&) at /home/asias/src/cloudius-systems/scylla/seastar/core/future.hh:1377 seastar::future<seastar::temporary_buffer<char> > seastar::future<>::then<seastar::net::native_connected_socket_impl<seastar::net::tcp<seastar::net::ipv4_traits> >::native_data_source_impl::get()::{lambda()#2}, seastar::future<seastar::temporary_buffer<char> > >(seastar::net::native_connected_socket_impl<seastar::net::tcp<seastar::net::ipv4_traits> >::native_data_source_impl::get()::{lambda()#2}&&) at /home/asias/src/cloudius-systems/scylla/seastar/core/future.hh:943 seastar::net::native_connected_socket_impl<seastar::net::tcp<seastar::net::ipv4_traits> >::native_data_source_impl::get() at /home/asias/src/cloudius-systems/scylla/seastar/net/native-stack-impl.hh:149 seastar::data_source::get() at /home/asias/src/cloudius-systems/scylla/seastar/core/iostream.hh:67 (inlined by) seastar::input_stream<char>::read_exactly_part(unsigned long, seastar::temporary_buffer<char>, unsigned long) at /home/asias/src/cloudius-systems/scylla/seastar/core/iostream-impl.hh:164 seastar::input_stream<char>::read_exactly(unsigned long) at /home/asias/src/cloudius-systems/scylla/seastar/core/iostream-impl.hh:191 tcp_echo_server::connection::process() at /home/asias/src/cloudius-systems/scylla/seastar/seastar_example_from_shanshanpt/server.cc:86 (inlined by) tcp_echo_server::start()::{lambda()#1}::operator()() const::{lambda(seastar::connected_socket, {lambda()#1}::socket_address)#1}::operator()(seastar, seastar::connected_socket)::{lambda()#2}::operator()() const at /home/asias/src/cloudius-systems/scylla/seastar/seastar_example_from_shanshanpt/server.cc:113 seastar::internal::do_until_state<tcp_echo_server::start()::{lambda()#1}::operator()() const::{lambda(seastar::connected_socket, seastar::socket_address)#1}::operator()({lambda()#1}, seastar::connected_socket)::{lambda()#1}, tcp_echo_server::start()::{lambda()#1}::operator()() const::seastar::socket_address::operator()({lambda()#1}, seastar::connected_socket)::{lambda()#2}>::run_and_dispose() at /home/asias/src/cloudius-systems/scylla/seastar/core/future-util.hh:463 seastar::reactor::run_tasks(seastar::reactor::task_queue&) at /home/asias/src/cloudius-systems/scylla/seastar/core/reactor.cc:2597 seastar::reactor::run_some_tasks() at /home/asias/src/cloudius-systems/scylla/seastar/core/reactor.cc:3009 seastar::reactor::run_some_tasks() at /usr/include/c++/7/chrono:377 (inlined by) seastar::reactor::run() at /home/asias/src/cloudius-systems/scylla/seastar/core/reactor.cc:3156 seastar::app_template::run_deprecated(int, char**, std::function<void ()>&&) at /home/asias/src/cloudius-systems/scylla/seastar/core/app-template.cc:185 main at /home/asias/src/cloudius-systems/scylla/seastar/seastar_example_from_shanshanpt/server.cc:179 (discriminator 5) Message-Id: <06a6c0ccb82fd4fdde6f56a112a8eb6f659ee8ab.1526611968.git.asias@scylladb.com>
- Loading branch information