The first step to find out what the executables does to prevent debugging is to use the ltrace command on it, which will list the dynamic library calls which are called by the executed process and the signals which are received by that process.
If "ptrace" is called, then it means that the program likely uses it to check if any other process (such as a debugger) is attached to it and will terminate if it detects one. There's several ways to cirumvent this behavior, one of them being to overwrite the ptrace call with 0x90 which is the NOP instruction in assembly.
To do that, first use the command readelf on the executable to find out its entry point address. Open the program in gdb and set a breakpoint at the entry point address, then run it and use gdb's single step functionality to step through the program's assembly code until you find the ptrace call.
Note the address of the ptrace call and the next instruction. The difference between the two is the amount of bytes we need to replace with 0x90. To check which bytes exactly need to be replaced examine the ptrace access with gdb's x command, for example x/10xb would let you look at the next 10 bytes in hexadecimal format.
Note down the bytes that need to be replaced, then open the executable with a hex editor and find them. Replace the bytes with 0x90. It should now be possible to reverse engineer the program with gdb.