Cómo funcionan las transacciones

Introducción
Las transacciones son la unidad fundamental de ejecución en Stacks. Cada transacción se origina desde una cuenta de Stacks y se conserva en la historia de la red Stacks para la eternidad. Esta guía te ayuda a entender las transacciones de Stacks.
Ciclo de vida
Las transacciones pasan por fases antes de ser finalmente confirmadas.

Generar
Las transacciones se ensamblan según la especificación de codificación.
Validar y firmar
Las transacciones se validan para confirmar que tienen una estructura correcta. Las firmas requeridas se completan.
Difundir
Las transacciones se envían a un nodo.
Registrar
Un minero recibe transacciones, las verifica y las añade al mempool, un área de retención para todas las transacciones pendientes.
Procesar
Los mineros revisan el mempool y seleccionan transacciones para el siguiente bloque que se va a minar. Dependiendo del tipo de transacción, pueden ocurrir distintas acciones durante este paso. Por ejemplo, se podrían verificar las postcondiciones de una transferencia de tokens, acuñar tokens definidos por un contrato inteligente, o intentar llamar a un método de un contrato inteligente existente.
Confirmar
Los mineros proponen con éxito bloques con un conjunto de transacciones. Las transacciones contenidas se propagan correctamente a la red cuando los stackers las aprueban.
Una transacción puede tener uno de tres estados una vez que se registra: pendiente, éxito, o fallida.
Tipos
Stacks admite un conjunto de diferentes tipos de transacciones:
Tipo
Valor
Descripción
Cambio de tenure
TenureChange
Un cambio de tenure es un evento en la cadena de bloques de Stacks existente cuando un minero asume la responsabilidad de crear nuevos bloques de Stacks desde otro minero. Un cambio de tenure ocurre cuando se descubre un bloque de Stacks a partir de una sortición criptográfica. Realizado por stackers.
Bloque de cambio de tenure encontrado
TenureChange-BlockFound
A TenureChange-BlockFound la transacción es inducida por una sortición ganadora. Esto hace que el nuevo minero empiece a producir bloques y detiene al minero actual de producir más bloques.
Extensión de cambio de tenure
TenureChange-Extend
A TenureChange-Extend, que es inducida por los Stackers, reinicia el presupuesto de ejecución en curso del tenure actual, permitiendo así que el minero continúe produciendo bloques.
Transferencia de tokens
token_transfer
Transferencia de activos de un remitente a un destinatario
Despliegue de contrato
smart_contract
Instanciación del contrato
Llamada al contrato
contract_call
Llamada al contrato para una función pública que no es de solo lectura
Comisiones
Las comisiones se utilizan para incentivar a los mineros a confirmar transacciones en la cadena de bloques de Stacks. La comisión se calcula en función de la tarifa de comisión estimada y del tamaño de la transacción en bruto en bytes. La tarifa de comisión es una variable determinada por el mercado. Para la testnet, se establece en 1 micro-STX.
Nonces
Cada cuenta tiene una propiedad nonce que indica el número de transacciones procesadas para la cuenta dada. Los nonces son códigos de un solo uso, que comienzan en 0 para las cuentas nuevas y se incrementan en 1 en cada transacción.
Los nonces se añaden a todas las transacciones y ayudan a identificarlas en orden para garantizar que las transacciones se procesen en secuencia y evitar el procesamiento duplicado.
El mecanismo de consenso también garantiza que las transacciones no se "reproduzcan" de dos maneras. Primero, los nodos consultan sus salidas de transacciones no gastadas (UTXOs) para satisfacer sus condiciones de gasto en una nueva transacción. Segundo, los mensajes enviados entre nodos revisan los números de secuencia.
Cuando se construye una nueva transacción de transferencia de tokens, se necesita obtener y establecer el nonce más reciente de la cuenta.
Cómo se detectan y resuelven los huecos de nonce
Las transacciones de Stacks deben ejecutarse estrictamente en orden de nonce. Cuando se envía una transacción con un nonce superior al esperado, la red no la rechaza de inmediato; en su lugar, rastrea el hueco y espera a que lleguen los nonces que faltan.
A continuación se muestra un recorrido conceptual, con respuestas visuales de la API, de cómo se comporta el sistema cuando los nonces se envían fuera de orden.
Estado inicial (sin transacciones pendientes)
Interpretación
Todas las transacciones hasta el nonce
241se han ejecutadoLa red espera el nonce
242siguienteNo hay transacciones esperando actualmente en el mempool
No existen huecos de nonce
Envío de un nonce futuro (245)
Interpretación
Una transacción con nonce
245ahora está en el mempoolNonces
242,243, y244faltanLa ejecución no puede continuar hasta que se envíen esos nonces
possible_next_noncerefleja el nonce más alto observado + 1
Envío de un hueco parcial (243)
Interpretación
Nonce
243ahora está presente en el mempoolNonces
242y244siguen faltandoLa ejecución sigue bloqueada
La API distingue entre:
detected_mempool_nonces→ presentes pero no ejecutadosdetected_missing_nonces→ requeridos pero aún no vistos
Rellenando más huecos (244)
Interpretación
Nonces
243y244están ambos esperando en el mempoolNonce
242sigue faltandoLa ejecución permanece en pausa en
241
Todos los nonces requeridos presentes (242)
Interpretación
Todos los nonces requeridos (
242–245) ya están disponiblesNo quedan huecos
La red puede ejecutar transacciones secuencialmente
Después de que la ejecución se completa
Interpretación
Todas las transacciones pendientes se han ejecutado
El nonce de la cuenta ha avanzado a
245El siguiente nonce válido ahora es
246El estado del mempool vuelve a estar limpio
Última actualización
¿Te fue útil?