-
-
Notifications
You must be signed in to change notification settings - Fork 464
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Getting one garbage character from container.exec() #736
Comments
const readStream = async (
stream: stream.Duplex
): Promise<{ stdin: string; stdout: string; stderr: string }> => {
let stdin = '';
let stdout = '';
let stderr = '';
return new Promise<{ stdin: string; stdout: string; stderr: string }>((resolve, reject) => {
let buffer = Buffer.alloc(0); // Accumulate unprocessed data
stream.on('data', (chunk: Buffer) => {
buffer = Buffer.concat([buffer, chunk]);
while (buffer.length >= 8) {
// Parse the header
const header = buffer.slice(0, 8);
const streamType = header[0]; // First byte indicates the stream type (0, 1, or 2)
const size = header.readUInt32BE(4); // Last 4 bytes indicate the payload size (big-endian)
// Check if the full frame is available
if (buffer.length < 8 + size) {
break; // Wait for more data if the payload is incomplete
}
// Extract the payload
const payload = buffer.slice(8, 8 + size).toString('utf-8');
// Append the payload to the appropriate stream
if (streamType === 0) {
stdin += payload;
} else if (streamType === 1) {
stdout += payload;
} else if (streamType === 2) {
stderr += payload;
}
// Remove the processed frame from the buffer
buffer = buffer.slice(8 + size);
}
});
stream.on('end', () => {
resolve({ stdin, stdout, stderr });
});
stream.on('error', (err) => {
reject(err);
});
});
}; May be this function can help you. |
Interesting, I will try this. Any explanation why this would work? |
@Fhwang0926 Were you able to figure out any solution? |
When you do not use the tty flag, Docker sends data with the first four bytes set to tell you whether the data is from stdout or stderr, and its length. This is the "garbage" that you're seeing at the start of the line. See "Stream format" within https://docs.docker.com/reference/api/engine/version/v1.43/#tag/Container/operation/ContainerAttach |
Thanks for @ewanmellor , i write the new func to read data, it work now. @jamesmurdza |
This is so useful that I feel the library's 'modem.demuxStream' is just a toy. When I really want to get the output content instead of outputting it directly to stdout or stderr (there is no function to separate them), I can only parse it manually. Of course, I am not sure if there is a problem with my writing. As a beginner, I find it completely difficult to understand the readme. |
Wow, thanks for finally solving this! |
I've written two helper functions using Dockerode. The idea is to run a command synchronously and then return the results as a string.
It works well, except each chunk that is returned by stream.on('data') starts with a garbage character, like "X", "*", "!", etc. I can't figure out why.
This happens for multiple commands, such as "bash" and "cat".
Help is much appreciated!
My code below:
The text was updated successfully, but these errors were encountered: