Software Engineer 2 - Back-End (Hadoop & Microservices)
- Location: Annapolis Junction, MD (On-site)
- Clearance Required: TS/SCI with MPO FS poly
- Openings: 1
- Posting Number: CP-1513-1-SWE2-MMSC-EC3
Overview
The BH/AV PRIME program is seeking a Software Engineer 2 with strong back-end development experience-particularly in Hadoop and microservices-to join a small, high-impact software team. If taking ideas from concept to working prototype in fast, iterative cycles excites you, and you enjoy solving complex problems in distributed systems, this role will give you the opportunity to have outsized impact on how our organization operates. You will work as a hands-on engineer on a close-knit team, designing and building scalable back-end services and data-intensive systems that support mission-critical applications.
Who This Role Fits
An experienced, hands-on back-end developer who thrives in small, highly-impactful teams. This individual possesses a strong passion for taking ideas from concept to prototype in rapid, iterative cycles, and enjoys solving complex distributed system and big-data challenges.
Responsibilities
- Design, develop, maintain, and enhance complex back-end software systems based on documented requirements.
- Implement services and data pipelines using Hadoop and related big-data technologies.
- Build and evolve microservices-based architectures, including service boundaries, APIs, and inter-service communication patterns.
- Utilize sound software design and development methodologies to build, integrate, and execute simulations in development and test environments.
- Provide input to system and software design, including hardware/software trade-offs, software reuse strategies, and effective use of COTS/GOTS components versus new development.
- Perform requirements analysis and synthesis from system level down to individual services and modules.
- Implement and consume RESTful APIs to integrate back-end services with other systems and client applications.
- Containerize services (e.g., Podman/Docker) and deploy them to orchestrated environments (e.g., Kubernetes).
- Diagnose and resolve complex issues in distributed systems, including performance analysis, latency reduction, and scalability tuning.
- Apply strong analytical troubleshooting and performance evaluation techniques across the stack.
- Collaborate with team members and stakeholders to refine requirements, estimate work, and deliver incremental value.
- Participate in code reviews, testing, and continuous improvement of engineering practices.
- Work independently when needed, demonstrating ownership, follow-through, and clear communication.
Education / Experience
- Bachelor's degree in Computer Engineering, Computer Science, Electrical Engineering, Math, or Physics is required or equivalent combination of education, training, and experience
- 14
Required Skills
- Strong Java development skills for back-end and service-layer implementations.
- Experience building and consuming RESTful services.
- Hands-on experience with containers (Podman and/or Docker).
- Experience with container orchestration platforms such as Kubernetes.
- Practical experience designing and implementing microservices architectures.
- Back-end development experience with Hadoop or similar big-data processing frameworks.
Familiarity With Two or More
- Machine Learning workflows
- streaming data processing
- batch processing pipelines
- MongoDB
- ArangoDB
- Redis
- PostgreSQL
Preferred / Desired Skills
- Experience deploying and operating applications in cloud environments such as AWS or on hyper-converged infrastructure (HCI).
- Familiarity with observability tools (logging, metrics, tracing) for distributed systems.
- Experience working in agile or iterative development environments.
Additional Information
- Both low and high side access.
- Project/TTO: 1513-1
- Program: BH/AV PRIME